:root{--color-dark:#03045e;--color-primary:#0077b6;--color-accent:#00b4d8;--color-light:#90e0ef;--color-bg:#caf0f8;--color-white:#fff;color:var(--color-dark);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0;overflow-x:clip}#root{min-height:100vh}a{color:var(--color-primary);font-weight:500;text-decoration:none}a:hover{color:var(--color-accent)}button,input{font-family:inherit}.page h1{color:var(--color-dark);margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.page .page-subtitle{color:var(--color-primary);margin:0 0 1.5rem;font-size:.95rem}.articles-page h1,.events-page h1{color:var(--color-dark);margin:0 0 .35rem;font-size:clamp(1.35rem,4vw,1.75rem);font-weight:700;line-height:1.2}.articles-page .page-subtitle,.events-page .page-subtitle{color:var(--color-primary);max-width:65ch;margin:0 0 1.25rem;font-size:clamp(.875rem,2.8vw,.95rem);line-height:1.45}@media (max-width:480px){.articles-page .page-subtitle,.events-page .page-subtitle{margin-bottom:1rem}}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}button:focus:not(:focus-visible){outline:none}.loading-screen{background:var(--color-bg);flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100vh;display:flex}.loading-screen p{color:var(--color-primary);margin:0;font-size:.95rem}.loading-spinner{border:3px solid var(--color-light);border-top-color:var(--color-accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--color-white);border-right:1px solid var(--color-light);flex-shrink:0;width:220px}.sidebar-header{border-bottom:1px solid var(--color-light);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.sidebar-brand{color:var(--color-dark);font-size:1.1rem;font-weight:700}.sidebar-close{cursor:pointer;color:var(--color-primary);background:0 0;border:none;border-radius:8px;min-width:44px;min-height:44px;padding:0;font-size:1.5rem;line-height:1;display:none}.sidebar-nav{padding:.75rem 0}.nav-link{min-height:44px;color:var(--color-primary);align-items:center;padding:.65rem 1.25rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-link:hover{background:var(--color-bg);color:var(--color-accent)}.nav-link.active{background:var(--color-bg);color:var(--color-dark);border-right:3px solid var(--color-accent);font-weight:600}.main-wrap{flex-direction:column;flex:1;min-width:0;display:flex}.main-header{padding:max(.5rem, env(safe-area-inset-top,0px)) max(1rem, env(safe-area-inset-right,0px)) .5rem max(1rem, env(safe-area-inset-left,0px));background:var(--color-white);border-bottom:1px solid var(--color-light);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.menu-toggle{cursor:pointer;color:var(--color-primary);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:0;font-size:1.35rem;display:none}.header-right{align-items:center;gap:1rem;display:flex}.user-name{color:var(--color-dark);font-size:.9rem}.logout-btn{min-height:44px;color:var(--color-primary);border:1px solid var(--color-primary);cursor:pointer;background:0 0;border-radius:6px;padding:.45rem 1rem;font-size:.875rem;font-weight:600;transition:all .15s}.logout-btn:hover{background:var(--color-primary);color:var(--color-white)}.main-content{padding:1.25rem;padding-bottom:max(1.25rem, env(safe-area-inset-bottom,0px));padding-left:max(1.25rem, env(safe-area-inset-left,0px));padding-right:max(1.25rem, env(safe-area-inset-right,0px));flex:1;overflow:auto}.sidebar-overlay{display:none}@media (max-width:768px){.sidebar{z-index:100;height:100%;transition:transform .2s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-close{display:block}.menu-toggle{display:inline-flex}.sidebar-overlay{z-index:99;background:#03045e4d;display:block;position:fixed;inset:0}.user-name{display:none}.main-content{padding:1rem}}.login-page{background:linear-gradient(135deg, var(--color-dark) 0%, var(--color-primary) 50%, var(--color-accent) 100%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{background:var(--color-white);border-radius:16px;width:100%;max-width:420px;padding:clamp(1.5rem,5vw,2.5rem);box-shadow:0 25px 50px -12px #03045e59}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:var(--color-dark);margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.login-header p{color:var(--color-primary);margin:0;font-size:.95rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.login-message{border-radius:8px;padding:.75rem 1rem;font-size:.9rem}.login-message.error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.login-message.success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group label{color:var(--color-dark);font-size:.875rem;font-weight:600}.form-group input{border:2px solid var(--color-light);background:var(--color-bg);min-height:48px;color:var(--color-dark);border-radius:8px;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input::placeholder{color:#94a3b8}.form-group input:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #00b4d833}.form-group input.invalid{border-color:#dc2626}.form-group input.invalid:focus{box-shadow:0 0 0 3px #dc262633}.form-group input:disabled{opacity:.7;cursor:not-allowed}.field-error{color:#dc2626;font-size:.8rem}.login-btn{min-height:48px;color:var(--color-white);background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);cursor:pointer;border:none;border-radius:8px;margin-top:.5rem;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;transition:opacity .2s,transform .15s}.login-btn:hover:not(:disabled){opacity:.95;transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.dashboard-page h1{color:var(--color-dark);margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--color-primary);margin:0 0 1.5rem;font-size:.95rem}.dashboard-cards{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;display:grid}.stat-card{background:var(--color-white);border:1px solid var(--color-light);border-radius:8px;padding:1.25rem}.stat-label{color:var(--color-primary);margin-bottom:.25rem;font-size:.875rem;display:block}.stat-value{color:var(--color-dark);font-size:1.5rem;font-weight:700}.users-page{width:100%;max-width:1200px;margin:0 auto}.users-toolbar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.toolbar-search input{border:1px solid var(--color-light);background:var(--color-white);border-radius:8px;width:220px;max-width:100%;min-height:44px;padding:.55rem .75rem;font-size:1rem}.toolbar-search input:focus{border-color:var(--color-accent);outline:none}.toolbar-filters{flex-wrap:wrap;gap:.5rem;display:flex}.toolbar-filters select,.toolbar-filters input{border:1px solid var(--color-light);background:var(--color-white);border-radius:8px;min-height:44px;padding:.55rem .75rem;font-size:1rem}.toolbar-filters input{width:120px}.toolbar-filters input::placeholder{color:#94a3b8}.toolbar-filters select:focus,.toolbar-filters input:focus{border-color:var(--color-accent);outline:none}.users-error{color:#b91c1c;background:#fef2f2;border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.users-loading,.users-empty{text-align:center;color:var(--color-primary);background:var(--color-white);border:1px solid var(--color-light);border-radius:8px;padding:3rem 1rem;font-size:.95rem}.users-table-wrap{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;border:1px solid var(--color-light);background:var(--color-white);border-radius:8px;overflow-x:auto}.users-table{border-collapse:collapse;width:100%;min-width:720px;font-size:.9rem}.users-table th,.users-table td{text-align:left;border-bottom:1px solid var(--color-light);padding:.6rem .9rem}.users-table th{color:var(--color-dark);background:var(--color-bg);font-weight:600}.users-table th:last-child,.users-table td:last-child{padding-right:1rem}.users-table tbody tr:hover{background:#caf0f866}.users-table tbody tr:last-child td{border-bottom:none}.user-cell{align-items:center;gap:.5rem;display:flex}.user-avatar{object-fit:cover;border-radius:50%;width:28px;height:28px}.status-active{color:#166534;background:#dcfce7}.status-inactive{color:#b91c1c;background:#fef2f2}.action-btn{width:32px;height:32px;color:var(--color-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;margin:0 2px;padding:0;transition:background .15s,color .15s;display:inline-flex}.view-modal{background:var(--color-white);border-radius:10px;width:100%;max-width:420px;max-height:90vh;overflow:auto;box-shadow:0 25px 50px -12px #03045e4d}.modal-close:hover{background:var(--color-bg)}.view-avatar-wrap{text-align:center;margin-bottom:1rem}.view-avatar{object-fit:cover;border-radius:50%;width:80px;height:80px}.users-pagination{border-top:1px solid var(--color-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:1rem;padding-top:1rem;display:flex}.pagination-info{color:var(--color-primary);font-size:.9rem}.pagination-btns{align-items:center;gap:.75rem;display:flex}.pagination-btns button{color:var(--color-primary);background:var(--color-white);border:1px solid var(--color-light);cursor:pointer;border-radius:6px;padding:.4rem .8rem;font-size:.9rem;font-weight:500;transition:all .15s}.pagination-btns button:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-accent)}.pagination-btns button:disabled{opacity:.5;cursor:not-allowed}.page-num{color:var(--color-dark);font-size:.9rem}@media (max-width:768px){.users-toolbar{flex-direction:column;align-items:stretch}.toolbar-search input{width:100%}.toolbar-filters{flex-direction:column;width:100%}.toolbar-filters select,.toolbar-filters input{width:100%;max-width:none}.toolbar-filters input{flex:1;min-width:0}.users-table{font-size:.85rem}.users-table th,.users-table td{padding:.6rem .5rem}.users-pagination{flex-direction:column;align-items:stretch;gap:.75rem}.pagination-btns{flex-wrap:wrap;justify-content:space-between;width:100%}.pagination-btns button{min-height:44px}}.articles-page{width:100%;max-width:1200px;margin:0 auto}.articles-toolbar{flex-wrap:wrap;align-items:stretch;gap:.75rem;margin-bottom:1rem;display:flex}.btn-post-article{min-height:44px;color:var(--color-white,#fff);background:var(--color-primary,#0891b2);cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.1rem;font-size:.9rem;font-weight:600}.btn-post-article:hover{filter:brightness(1.05)}.btn-post-article:focus-visible{outline:2px solid var(--color-accent,#06b6d4);outline-offset:2px}.articles-toolbar .toolbar-filters{flex-wrap:wrap;flex:1;gap:.5rem;min-width:min(100%,280px);display:flex}.articles-toolbar select{border:1px solid var(--color-light);background:var(--color-white);border-radius:8px;min-height:44px;padding:.55rem .75rem;font-size:1rem}.articles-toolbar select:focus{border-color:var(--color-accent);outline:none}.articles-error{color:#b91c1c;background:#fef2f2;border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.articles-loading,.articles-empty{text-align:center;color:var(--color-primary);background:var(--color-white);border:1px solid var(--color-light);border-radius:8px;padding:3rem 1rem;font-size:.95rem}.articles-table-wrap{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;border:1px solid var(--color-light);background:var(--color-white);border-radius:8px;overflow-x:auto}.articles-table{border-collapse:collapse;width:100%;min-width:640px;font-size:.9rem}.articles-table th,.articles-table td{text-align:left;border-bottom:1px solid var(--color-light);padding:.6rem .9rem}.articles-table th{color:var(--color-dark);background:var(--color-bg);font-weight:600}.articles-table tbody tr:hover{background:#caf0f866}.articles-table tbody tr:last-child td{border-bottom:none}.article-cell{align-items:center;gap:.75rem;display:flex}.article-thumb{object-fit:cover;border-radius:4px;flex-shrink:0;width:48px;height:36px}.article-title{color:var(--color-dark);font-weight:500;display:block}.article-excerpt{color:#64748b;margin-top:.15rem;font-size:.8rem;display:block}.status-badge{border-radius:4px;padding:.2rem .5rem;font-size:.8rem;font-weight:500;display:inline-block}.status-published{color:#166534;background:#dcfce7}.status-draft{color:#64748b;background:#f1f5f9}.status-pending{color:#854d0e;background:#fef9c3}.status-archived{color:#b91c1c;background:#fef2f2}.status-unknown{color:#64748b;background:#f1f5f9}.actions-col{text-align:center;width:110px}.actions-cell{white-space:nowrap}.action-btn{width:40px;min-width:40px;height:40px;min-height:40px;color:var(--color-primary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;margin:0 2px;padding:0;transition:background .15s,color .15s;display:inline-flex}.action-btn:hover{background:var(--color-bg);color:var(--color-accent)}.action-btn.action-delete:hover{color:#b91c1c;background:#fef2f2}.action-btn:disabled{opacity:.5;cursor:not-allowed}.view-modal-overlay{z-index:1000;background:#03045e66;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.view-modal{background:var(--color-white);border-radius:10px;width:100%;max-width:560px;max-height:min(90vh,100dvh);margin:auto;overflow:auto;box-shadow:0 25px 50px -12px #03045e4d}.view-modal-header{border-bottom:1px solid var(--color-light);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.view-modal-header h3{color:var(--color-dark);margin:0;font-size:1.1rem}.modal-close{width:32px;height:32px;color:var(--color-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:0;font-size:1.5rem;line-height:1}.modal-close:hover:not(:disabled){background:var(--color-bg)}.view-modal-body{padding:1.25rem}.view-loading{text-align:center;color:var(--color-primary);padding:2rem}.view-image-wrap{margin-bottom:1rem}.view-image{object-fit:cover;border-radius:6px;width:100%;max-height:200px}.view-details{gap:.6rem;margin:0;display:grid}.view-details div{grid-template-columns:minmax(88px,110px) 1fr;align-items:start;gap:.5rem;display:grid}.view-details dt{color:var(--color-primary);margin:0;font-size:.85rem;font-weight:600}.view-details dd{color:var(--color-dark);margin:0;font-size:.9rem}.view-details .view-body{white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto}.articles-pagination{border-top:1px solid var(--color-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:1rem;padding-top:1rem;display:flex}.articles-pagination .pagination-info{color:var(--color-primary);font-size:.9rem}.articles-pagination .pagination-btns{align-items:center;gap:.75rem;display:flex}.articles-pagination .pagination-btns button{color:var(--color-primary);background:var(--color-white);border:1px solid var(--color-light);cursor:pointer;border-radius:6px;padding:.4rem .8rem;font-size:.9rem;font-weight:500;transition:all .15s}.articles-pagination .pagination-btns button:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-accent)}.articles-pagination .pagination-btns button:disabled{opacity:.5;cursor:not-allowed}.articles-pagination .page-num{color:var(--color-dark);font-size:.9rem}@media (max-width:768px){.articles-toolbar{flex-direction:column;align-items:stretch}.articles-toolbar .toolbar-filters{flex-direction:column;min-width:100%}.articles-toolbar .toolbar-filters select{width:100%}.article-cell{flex-direction:column;align-items:flex-start}.articles-table{font-size:.85rem}.articles-table th,.articles-table td{padding:.65rem .5rem}.articles-pagination{flex-direction:column;align-items:stretch;gap:.75rem}.articles-pagination .pagination-btns{flex-wrap:wrap;justify-content:space-between;width:100%}.articles-pagination .pagination-btns button{min-height:44px;padding:.5rem 1rem}.view-modal-overlay{align-items:flex-end;padding:0}.view-modal{border-radius:12px 12px 0 0;width:100%;max-width:none;max-height:92dvh}.view-details div{grid-template-columns:1fr;gap:.15rem}.view-details dt{text-transform:uppercase;letter-spacing:.03em;color:var(--color-accent);font-size:.75rem}}@media (max-width:480px){.articles-table{min-width:580px}.action-btn{width:44px;min-width:44px;height:44px;min-height:44px}}.rich-editor-wrap{border:1px solid var(--color-light);background:var(--color-white);border-radius:6px;overflow:hidden}.rich-editor-loading{color:var(--color-primary);border:1px solid var(--color-light);background:var(--color-white);border-radius:6px;padding:1rem;font-size:.9rem}.rich-editor-toolbar{background:var(--color-bg);border-bottom:1px solid var(--color-light);flex-wrap:wrap;align-items:center;gap:.25rem;padding:.4rem .5rem;display:flex}.rich-editor-toolbar button{color:var(--color-dark);background:var(--color-white);border:1px solid var(--color-light);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;min-width:32px;padding:.4rem;font-size:.75rem;font-weight:600;display:inline-flex}.rich-editor-toolbar button:hover{background:var(--color-light);border-color:var(--color-accent)}.rich-editor-toolbar button.active{background:var(--color-accent);color:var(--color-white);border-color:var(--color-accent)}.toolbar-sep{background:var(--color-light);width:1px;height:20px;margin:0 .25rem}.rich-editor-content{min-height:200px}.rich-editor-content .ProseMirror{outline:none;min-height:200px;padding:.75rem 1rem;font-size:.95rem;line-height:1.6}.rich-editor-content .ProseMirror p{margin:0 0 .5rem}.rich-editor-content .ProseMirror p:last-child{margin-bottom:0}.rich-editor-content .ProseMirror h1,.rich-editor-content .ProseMirror h2{margin:1rem 0 .5rem}.rich-editor-content .ProseMirror ul,.rich-editor-content .ProseMirror ol{margin:.5rem 0;padding-left:1.5rem}.rich-editor-content .ProseMirror img.editor-image{border-radius:4px;max-width:100%;height:auto}.rich-editor-content .ProseMirror:focus{outline:none}.rich-editor-content .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:#94a3b8;float:left;pointer-events:none;height:0}@media (max-width:640px){.rich-editor-toolbar{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:thin;flex-wrap:nowrap;gap:.35rem;padding:.5rem;overflow-x:auto}.rich-editor-toolbar button{flex-shrink:0;min-width:42px;min-height:42px;font-size:.8rem}.toolbar-sep{flex-shrink:0}.rich-editor-content .ProseMirror{min-height:160px;font-size:1rem}.rich-editor-content{min-height:160px}}.place-autocomplete{width:100%;position:relative}.place-input-wrap{align-items:center;display:flex;position:relative}.place-input{border:1px solid var(--color-light);background:var(--color-white);border-radius:8px;width:100%;min-height:44px;padding:.6rem 2.25rem .6rem .85rem;font-size:1rem}.place-input:focus{border-color:var(--color-accent);outline:none}.place-clear{width:40px;height:40px;color:var(--color-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;font-size:1.25rem;line-height:1;display:inline-flex;position:absolute;top:50%;right:.2rem;transform:translateY(-50%)}.place-clear:hover{background:var(--color-bg)}.place-loading{color:var(--color-primary);font-size:.8rem;position:absolute;top:50%;right:2.85rem;transform:translateY(-50%)}.place-dropdown{background:var(--color-white);border:1px solid var(--color-light);-webkit-overflow-scrolling:touch;z-index:200;border-top:none;border-radius:0 0 6px 6px;max-height:min(220px,45vh);margin:0;padding:.25rem 0;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #03045e1a}.place-option{cursor:pointer;flex-direction:column;gap:.15rem;min-height:44px;padding:.65rem .85rem;display:flex}.place-option:hover,.place-option.highlight{background:var(--color-bg)}.place-option-name{color:var(--color-dark);font-weight:500}.place-option-meta{color:var(--color-primary);font-size:.8rem}.article-edit-page{width:100%;max-width:960px;margin:0 auto}.edit-header{margin-bottom:1.5rem}.edit-loading,.edit-error{text-align:center;color:var(--color-primary);background:var(--color-white);border:1px solid var(--color-light);border-radius:8px;padding:2rem}.edit-error{color:#b91c1c;margin-bottom:1rem}.back-btn{color:var(--color-primary);background:var(--color-white);border:1px solid var(--color-primary);cursor:pointer;border-radius:6px;padding:.5rem 1rem;font-size:.9rem}.back-btn:hover{background:var(--color-bg)}.article-form{background:var(--color-white);border:1px solid var(--color-light);padding:1.5rem;padding-bottom:max(1.5rem, env(safe-area-inset-bottom,0px));border-radius:8px}.form-error{color:#b91c1c;background:#fef2f2;border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.form-section{margin-bottom:1.5rem}.form-section h3{color:var(--color-dark);border-bottom:1px solid var(--color-light);margin:0 0 1rem;padding-bottom:.5rem;font-size:1rem;font-weight:600}.form-row{margin-bottom:1rem}.form-row label{color:var(--color-dark);margin-bottom:.35rem;font-size:.875rem;font-weight:500;display:block}.form-row input,.form-row select,.form-row textarea{border:1px solid var(--color-light);background:var(--color-white);border-radius:8px;width:100%;min-height:44px;padding:.6rem .85rem;font-size:1rem}.form-row textarea{resize:vertical;min-height:88px}.form-row select{cursor:pointer}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--color-accent);outline:none}.form-row-inline{flex-wrap:wrap;gap:1rem;display:flex}.form-row-inline>div{flex:1;min-width:140px}.form-row-place{min-width:200px}.article-images-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;display:grid}.article-image-card{border:1px solid var(--color-light);background:var(--color-bg);border-radius:8px;overflow:hidden}.article-image-card.is-default{border-color:var(--color-accent);box-shadow:0 0 0 2px #00b4d84d}.article-image-preview{aspect-ratio:4/3;object-fit:cover;width:100%;display:block}.article-image-info{flex-direction:column;gap:.35rem;padding:.5rem .75rem;display:flex}.article-image-alt{color:var(--color-dark);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;overflow:hidden}.article-image-default{color:var(--color-primary);cursor:pointer;align-items:center;gap:.35rem;margin:0;font-size:.8rem;font-weight:500;display:flex}.article-image-default input{width:auto}.article-image-new .article-image-info{gap:.5rem}.article-image-input{border:1px solid var(--color-light);border-radius:4px;width:100%;padding:.35rem .5rem;font-size:.85rem}.article-image-input:focus{border-color:var(--color-accent);outline:none}.article-image-remove{color:#b91c1c;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;padding:.25rem .5rem;font-size:.8rem}.article-image-remove:hover{background:#fee2e2}.article-add-images{margin-top:1rem}.article-add-images-input{opacity:0;z-index:-1;width:.1px;height:.1px;position:absolute;overflow:hidden}.article-add-images-btn{color:var(--color-primary);background:var(--color-bg);border:2px dashed var(--color-light);cursor:pointer;border-radius:6px;padding:.5rem 1rem;font-size:.9rem;font-weight:500;transition:border-color .15s,background .15s;display:inline-block}.article-add-images-btn:hover{border-color:var(--color-accent);background:#90e0ef4d}.form-row-check{align-items:center;gap:.5rem;margin-top:1.5rem;display:flex}.form-row-check input{width:auto}.form-row-check label{margin:0;font-weight:500}.form-actions{border-top:1px solid var(--color-light);flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;padding-top:1rem;display:flex}.btn-cancel{min-height:48px;color:var(--color-primary);border:1px solid var(--color-light);cursor:pointer;background:0 0;border-radius:8px;padding:.6rem 1.25rem;font-size:1rem}.btn-cancel:hover{background:var(--color-bg)}.btn-submit{min-height:48px;color:var(--color-white);background:var(--color-primary);cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.25rem;font-size:1rem;font-weight:600}.btn-submit:hover:not(:disabled){background:var(--color-accent)}.btn-submit:disabled{opacity:.7;cursor:not-allowed}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.category-fieldset{border:none;margin:0;padding:0}.category-checkboxes{flex-wrap:wrap;gap:.5rem 1.25rem;display:flex}.category-check{cursor:pointer;align-items:center;gap:.35rem;font-size:.9rem;display:inline-flex}.category-check input{margin:0}.categories-loading,.categories-empty{color:var(--color-primary);margin:0;font-size:.9rem}.form-hint{color:var(--color-primary);margin:0 0 .75rem;font-size:.85rem}@media (max-width:768px){.article-form{border-left:none;border-right:none;border-radius:0;padding:1.1rem}.form-row-inline{flex-direction:column}.form-row-inline>div{min-width:100%}.form-actions{background:linear-gradient(to top, var(--color-white) 70%, transparent);padding-bottom:max(.75rem, env(safe-area-inset-bottom,0px));flex-direction:column-reverse;margin-top:2rem;position:sticky;bottom:0}.form-actions .btn-cancel,.form-actions .btn-submit{justify-content:center;width:100%}.category-checkboxes{gap:.65rem 1rem}.category-check{min-height:44px;padding:.2rem 0}}.events-page .events-toolbar{align-items:flex-start}.events-toolbar-filters{max-width:100%}.events-search{border:1px solid var(--color-light);border-radius:6px;min-width:200px;padding:.5rem .75rem;font-size:.9rem}.events-place-filter{border:1px solid var(--color-light);border-radius:6px;width:110px;padding:.5rem;font-size:.85rem}.events-apply-btn{background:var(--color-white);border:1px solid var(--color-light);cursor:pointer;color:var(--color-primary);border-radius:6px;padding:.5rem 1rem;font-size:.9rem}.events-apply-btn:hover{border-color:var(--color-accent);background:var(--color-bg)}.events-filter-chips{flex-wrap:wrap;align-items:center;gap:.5rem;width:100%;margin-top:.15rem;padding:.35rem 0;display:flex}button.events-filter-chip{color:var(--color-dark);white-space:nowrap;cursor:pointer;border:1px solid var(--color-light);background:var(--color-white);-webkit-user-select:none;user-select:none;appearance:none;-webkit-tap-highlight-color:transparent;border-radius:999px;flex:none;justify-content:center;align-items:center;gap:.45rem;width:auto;max-width:100%;margin:0;padding:.4rem .75rem;font-family:inherit;font-size:.875rem;font-weight:500;line-height:1.2;transition:border-color .15s,background .15s,box-shadow .15s;display:inline-flex;box-shadow:0 1px 2px #03045e0f}button.events-filter-chip:hover{border-color:var(--color-accent);background:var(--color-bg)}button.events-filter-chip:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button.events-filter-chip[aria-pressed=true]{border-color:var(--color-primary);color:var(--color-dark);background:#caf0f8bf;box-shadow:0 0 0 2px #00b4d840}.status-approved{color:#166534;background:#dcfce7}.status-rejected{color:#991b1b;background:#fee2e2}.status-cancelled{color:#4b5563;background:#f3f4f6}.view-modal-wide{max-width:640px}.view-details-events div{grid-template-columns:100px 1fr}.event-sponsor-row{border:1px solid var(--color-light);border-radius:6px;gap:.5rem;margin-bottom:.75rem;padding:.75rem;display:grid}.events-page{width:100%;max-width:1200px;margin:0 auto}.events-toolbar{gap:.65rem}.events-search{border-radius:8px;flex:1;min-width:min(100%,200px);min-height:44px;font-size:1rem}.events-apply-btn{border-radius:8px;min-height:44px;font-weight:500}.events-place-filter{width:100%;max-width:160px;min-height:44px;font-size:1rem}.events-toolbar .toolbar-filters select,.events-toolbar .toolbar-filters input[type=date],.events-toolbar .toolbar-filters input[type=text]{border-radius:8px;min-height:44px;font-size:1rem}.events-toolbar .toolbar-filters{flex:1;min-width:min(100%,240px)}@media (max-width:768px){.events-toolbar{flex-direction:column;align-items:stretch}.events-toolbar-filters{flex-direction:column;width:100%}.events-toolbar-filters select,.events-toolbar-filters input[type=date],.events-toolbar-filters input[type=text]{width:100%;max-width:none}.events-filter-chips{justify-content:flex-start;gap:.45rem}.events-filter-chip{min-height:44px;padding:.45rem .85rem}.view-details-events div{grid-template-columns:1fr}}.access-control-page{max-width:960px}.access-muted{color:var(--color-primary);margin:0}.access-banner{border-radius:8px;margin-bottom:1rem;padding:.65rem 1rem;font-size:.95rem}.access-banner--ok{color:var(--color-dark);background:#00b4d833}.access-banner--err{color:#b91c1c;background:#ef444426}.access-tabs{border-bottom:1px solid var(--color-light);gap:.35rem;margin-bottom:1.25rem;padding-bottom:.25rem;display:flex}.access-tab{color:var(--color-primary);cursor:pointer;background:0 0;border:none;border-radius:8px 8px 0 0;min-height:44px;padding:.5rem 1rem;font-weight:600}.access-tab:hover{background:var(--color-bg)}.access-tab.active{background:var(--color-white);color:var(--color-dark);box-shadow:0 -1px 0 var(--color-accent)}.access-section{margin-top:.5rem}.access-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.access-heading{color:var(--color-dark);margin:0;font-size:1.15rem;font-weight:700}.access-btn-primary{background:var(--color-primary);color:var(--color-white);cursor:pointer;border:none;border-radius:8px;min-height:44px;padding:.5rem 1rem;font-weight:600}.access-btn-primary:hover{background:var(--color-dark)}.access-btn-primary:disabled{opacity:.6;cursor:not-allowed}.access-btn-ghost{border:1px solid var(--color-light);background:var(--color-white);color:var(--color-dark);cursor:pointer;border-radius:8px;min-height:44px;padding:.5rem 1rem}.access-btn-link{color:var(--color-primary);cursor:pointer;background:0 0;border:none;min-height:44px;padding:.25rem .5rem;font-weight:600}.access-btn-link.danger{color:#b91c1c}.access-module-list{flex-direction:column;gap:1rem;display:flex}.access-module-card{background:var(--color-white);border:1px solid var(--color-light);border-radius:12px;overflow:hidden}.access-module-head{background:var(--color-bg);border-bottom:1px solid var(--color-light);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.access-module-head h3{color:var(--color-dark);margin:0;font-size:1rem}.access-badge{background:var(--color-white);color:var(--color-primary);border-radius:999px;padding:.2rem .5rem;font-size:.8rem}.access-perm-list{margin:0;padding:0;list-style:none}.access-perm-list li{border-bottom:1px solid var(--color-bg)}.access-perm-list li:last-child{border-bottom:none}.access-perm-row{justify-content:space-between;align-items:center;gap:1rem;padding:.65rem 1rem;display:flex}.access-slug{color:var(--color-primary);margin-top:.2rem;font-size:.8rem;display:block}.access-slug--inline{margin-left:.35rem;font-size:.75rem;display:inline}.access-table-wrap{background:var(--color-white);border:1px solid var(--color-light);border-radius:12px;overflow-x:auto}.access-table{border-collapse:collapse;width:100%;font-size:.95rem}.access-table th,.access-table td{text-align:left;border-bottom:1px solid var(--color-bg);padding:.65rem 1rem}.access-table th{color:var(--color-dark);background:var(--color-bg);font-weight:700}.access-table-actions{flex-wrap:wrap;justify-content:flex-end;gap:.25rem;display:flex}.access-modal-overlay{z-index:1000;background:#03045e59;justify-content:center;align-items:flex-start;padding:1.5rem 1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.access-modal{background:var(--color-white);border-radius:12px;width:100%;max-width:420px;margin-top:2rem;padding:1.25rem;box-shadow:0 12px 40px #0000001f}.access-modal--wide{max-width:560px}.access-modal h2{margin:0 0 1rem;font-size:1.2rem}.access-field{margin-bottom:1rem}.access-field label{color:var(--color-dark);margin-bottom:.35rem;font-weight:600;display:block}.access-field input,.access-field select{border:1px solid var(--color-light);border-radius:8px;width:100%;padding:.5rem .65rem;font-size:1rem}.access-fieldset{border:1px solid var(--color-light);border-radius:8px;margin:0 0 1rem;padding:.75rem}.access-fieldset legend{padding:0 .35rem;font-weight:700}.access-checkbox-grid{flex-direction:column;gap:.5rem;max-height:280px;margin-top:.5rem;display:flex;overflow:auto}.access-check{cursor:pointer;align-items:flex-start;gap:.5rem;font-size:.9rem;display:flex}.access-check input{margin-top:.2rem}.access-check-group{text-transform:uppercase;letter-spacing:.04em;color:var(--color-primary);margin-bottom:.15rem;font-size:.72rem;display:block}.access-modal-actions{justify-content:flex-end;gap:.5rem;margin-top:1rem;display:flex}.access-hint{color:var(--color-primary);margin:.35rem 0 0;font-size:.85rem}
