:root{--bg: #f8f9fb;--surface: #ffffff;--border: #e5e7eb;--border-strong: #d1d5db;--text: #111827;--text-muted: #6b7280;--text-muted-light: #9ca3af;--accent: #f18d22;--accent-hover: #d97a1a;--accent-bg: #fef5ec;--danger: #dc2626;--danger-bg: #fef2f2;--success: #059669;--success-bg: #ecfdf5;--sidebar-bg: #ffffff;--sidebar-border: #e5e7eb;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 1px 3px rgba(0, 0, 0, .06);--radius: 8px;--radius-lg: 10px}*{box-sizing:border-box}body{margin:0;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.5}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer;font-size:inherit}input{font-family:inherit;font-size:1rem}.layout{min-height:100vh;display:flex}.layout-sidebar{width:240px;flex-shrink:0;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column}.layout-brand{padding:1.25rem 1.25rem 1rem;font-weight:600;font-size:1.05rem;color:var(--text);border-bottom:1px solid var(--border);letter-spacing:-.02em}.layout-nav{flex:1;padding:.75rem 0}.layout-nav-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;color:var(--text-muted);text-decoration:none;font-size:.9rem;border-left:3px solid transparent;transition:color .15s,background .15s}.layout-nav-item:hover{color:var(--text);background:var(--bg)}.layout-nav-item.active{color:var(--accent);font-weight:500;background:var(--accent-bg);border-left-color:var(--accent)}.layout-nav-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem 1.25rem;background:none;border:none;border-left:3px solid transparent;color:var(--text-muted);font-size:.9rem;font:inherit;cursor:pointer;text-align:left;transition:color .15s,background .15s}.layout-nav-group-toggle:hover{color:var(--text);background:var(--bg)}.layout-nav-group-toggle.active{color:var(--accent);font-weight:500;background:var(--accent-bg);border-left-color:var(--accent)}.layout-nav-chevron{font-size:.6rem;color:var(--text-muted);transition:transform .2s}.layout-nav-group.open .layout-nav-chevron{transform:rotate(-180deg)}.layout-nav-sub{overflow:hidden;max-height:0;transition:max-height .2s ease-out}.layout-nav-group.open .layout-nav-sub{max-height:10rem}.layout-nav-sub-item{padding-left:2rem;font-size:.85rem}.layout-user{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:.5rem;background:var(--bg)}.layout-user-info{min-width:0}.layout-user-name{font-size:.875rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layout-user-role{font-size:.75rem;color:var(--text-muted)}.layout-main-wrap{flex:1;min-width:0;display:flex;flex-direction:column}.layout-header{flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;padding:.75rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border)}.layout-header .layout-user-info{text-align:right}.dropdown{position:relative}.dropdown-trigger{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem .4rem .75rem;background:none;border:none;border-radius:var(--radius);color:inherit;font:inherit;cursor:pointer;transition:background .15s}.dropdown-trigger:hover{background:var(--bg)}.dropdown-chevron{font-size:.6rem;color:var(--text-muted);transition:transform .2s}.dropdown.open .dropdown-chevron{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:.25rem;min-width:160px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:.25rem 0;z-index:100}.dropdown-item{display:block;width:100%;padding:.5rem 1rem;text-align:left;background:none;border:none;font:inherit;font-size:.9rem;color:var(--text);text-decoration:none;cursor:pointer;transition:background .15s}.dropdown-item:hover{background:var(--bg)}.dropdown-item-danger{color:var(--danger)}.dropdown-item-danger:hover{background:var(--danger-bg)}.layout-main{flex:1;padding:1.5rem}.btn{padding:.5rem 1rem;border-radius:var(--radius);border:none;font-weight:500;font-size:.9rem;transition:background .15s,color .15s}.btn-primary{background:var(--accent);color:#fff;padding:.65rem 1rem}.login-form .btn-primary{width:100%}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-muted);padding:.4rem .75rem;font-size:.875rem}.btn-ghost:hover{color:var(--text);background:var(--border)}.btn-sm{padding:.35rem .65rem;font-size:.8rem}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger-text{color:var(--danger)}.btn-danger-text:hover{background:var(--danger-bg);color:var(--danger)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#047857}.btn-muted{background:var(--border);color:var(--text-muted)}.btn-muted:hover:not(:disabled){background:#d1d5db;color:var(--text)}.app-loading,.page-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted);font-size:.9rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg)}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow)}.login-title{margin:0 0 .25rem;font-size:1.35rem;font-weight:600;color:var(--text);letter-spacing:-.02em}.login-subtitle{margin:0 0 1.5rem;color:var(--text-muted);font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1rem}.label{font-size:.8rem;font-weight:500;color:var(--text-muted);letter-spacing:.01em}.input{padding:.6rem .85rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);transition:border-color .15s}.input::placeholder{color:var(--text-muted-light)}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.form-error{margin:0;color:var(--danger);font-size:.85rem}.form-success{margin:0;color:var(--success);font-size:.9rem}.page-error{padding:1.5rem;color:var(--danger);font-size:.9rem}.page-breadcrumb{margin:0 0 .5rem;font-size:.9rem;color:var(--text-muted)}.page-breadcrumb a:hover{text-decoration:underline}.page-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem}.page-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text);letter-spacing:-.02em}.articles-pending-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .75rem;background:var(--accent-bg);border:1px solid var(--accent);border-radius:var(--radius);font-size:.875rem}.articles-pending-count{font-weight:700;color:var(--accent)}.articles-pending-label{color:var(--text-muted)}.section{margin-bottom:1.5rem}.section-title{margin:0 0 .75rem;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.filters-bar{margin-bottom:1rem;padding:1rem 1.25rem}.filters-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1rem}.filters-bar .form-row{margin:0;min-width:140px}.filters-bar .form-row label{display:block;margin-bottom:.25rem;font-size:.8rem;font-weight:500;color:var(--text-muted)}.filters-bar .input{min-width:160px}.filters-bar input[type=search]{min-width:200px}.filters-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.table th{font-weight:600;color:var(--text-muted);background:var(--bg);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.table tbody tr:hover{background:var(--bg)}.table tbody tr:last-child td{border-bottom:none}.table-empty{color:var(--text-muted);text-align:center;padding:2.5rem 1rem;font-size:.9rem}.table-actions-col{white-space:nowrap}.table-actions-col .btn{margin-right:.25rem}.badge{display:inline-block;padding:.2rem .5rem;background:var(--bg);color:var(--text-muted);border-radius:4px;font-size:.75rem;font-weight:500}.badge-success{background:var(--success-bg);color:var(--success)}.badge-muted{background:var(--border);color:var(--text-muted)}.badge-pending{background:#fef9c3;color:#a16207;border:1px solid #fde68a}.badge-published{background:var(--success-bg);color:var(--success);border:1px solid #6ee7b7}.badge-sold{background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd}.badge-removed{background:var(--border);color:var(--text-muted);border:1px solid var(--border)}.badge-rejected{background:var(--danger-bg);color:var(--danger);border:1px solid #fca5a5}.badge-role--user{background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}.badge-role--moderator{background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd}.badge-role--admin{background:var(--accent-bg);color:var(--accent-hover);border:1px solid var(--accent);font-weight:600}.table-row--user{background:var(--surface)}.table-row--moderator td:first-child{border-left:3px solid #93c5fd}.table-row--admin td:first-child{border-left:3px solid var(--accent)}.table-code{font-size:.8em;background:var(--bg);padding:.15rem .4rem;border-radius:4px;font-family:ui-monospace,monospace}.dashboard-intro{margin:0 0 1.5rem;color:var(--text-muted);font-size:.95rem;max-width:42rem}.dashboard-cards{display:flex;flex-wrap:wrap;gap:1.25rem}.dashboard-card{display:flex;align-items:flex-start;gap:1rem;padding:1.35rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;min-width:260px;max-width:320px;transition:border-left-color .2s,box-shadow .2s,background .2s,transform .15s;position:relative}.dashboard-card:hover{box-shadow:0 4px 12px #00000014;background:var(--accent-bg);border-left-color:var(--accent-hover);transform:translateY(-2px)}.dashboard-card:after{content:"→";position:absolute;right:1.25rem;top:50%;transform:translateY(-50%);font-size:1.1rem;color:var(--text-muted-light);opacity:0;transition:opacity .2s,right .2s}.dashboard-card:hover:after{opacity:1;right:1rem;color:var(--accent)}.dashboard-card-content{flex:1;min-width:0}.dashboard-card-title{display:block;font-weight:600;font-size:1.05rem;color:var(--text);margin-bottom:.35rem;letter-spacing:-.01em}.dashboard-card-desc{font-size:.875rem;color:var(--text-muted);line-height:1.4}.pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.75rem 1rem;border-top:1px solid var(--border);background:var(--bg);font-size:.875rem}.pagination-info{color:var(--text-muted)}.pagination-btns{display:flex;gap:.5rem}.pagination .btn-ghost:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 20px 40px #00000026;width:100%;max-width:440px;max-height:90vh;overflow:auto}.modal.modal-sm{max-width:380px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-title{margin:0;font-size:1.1rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--text-muted);padding:.25rem;cursor:pointer}.modal-close:hover{color:var(--text)}.modal-body{padding:1.25rem}.modal-body .form-row .input,.modal-body .form-row select,.modal-body .form-row textarea{width:100%;box-sizing:border-box}.modal-body .form-error{margin-bottom:.75rem}.form-row{margin-bottom:1rem}.form-row .label{display:block;margin-bottom:.35rem}.form-row-checkbox{margin-bottom:.5rem}.label-checkbox{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text);cursor:pointer}.label-checkbox input[type=checkbox]{width:1.1em;height:1.1em;cursor:pointer}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.confirm-message{margin:0 0 1rem;color:var(--text-muted);font-size:.95rem}.btn-link{background:none;border:none;padding:0;color:var(--text);font-size:inherit;font-weight:500;cursor:pointer;text-align:left;text-decoration:underline;text-decoration-color:transparent;transition:color .15s,text-decoration-color .15s}.btn-link:hover{color:var(--accent);text-decoration-color:var(--accent)}.modal-detail{max-width:600px;width:100%}.modal-detail .modal-body{padding:0}.article-gallery{background:#111;border-radius:0}.article-gallery-main{position:relative;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;overflow:hidden}.article-gallery-main img{max-width:100%;max-height:100%;object-fit:contain;display:block}.gallery-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#00000080;color:#fff;border:none;border-radius:50%;width:2.4rem;height:2.4rem;font-size:1.5rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s;z-index:1}.gallery-arrow:hover{background:#000c}.gallery-arrow-prev{left:.75rem}.gallery-arrow-next{right:.75rem}.article-gallery-thumbs{display:flex;gap:.4rem;padding:.5rem .75rem;background:#1a1a1a;justify-content:center}.article-gallery-thumb{background:none;border:2px solid transparent;border-radius:5px;overflow:hidden;cursor:pointer;width:56px;height:56px;padding:0;opacity:.6;transition:border-color .15s,opacity .15s;flex-shrink:0}.article-gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}.article-gallery-thumb.active,.article-gallery-thumb:hover{border-color:var(--accent);opacity:1}.article-gallery-empty{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2.5rem 1rem;color:var(--text-muted);font-size:.9rem;background:var(--bg);border-bottom:1px solid var(--border)}.article-detail-info{padding:1.25rem 1.5rem;display:flex;flex-direction:column}.article-detail-row{display:grid;grid-template-columns:110px 1fr;align-items:start;gap:.5rem;padding:.65rem 0;border-bottom:1px solid var(--border);font-size:.9rem}.article-detail-row:last-child{border-bottom:none}.article-detail-row--block{grid-template-columns:1fr;gap:.35rem}.article-detail-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted-light);padding-top:.15rem}.article-detail-row>:not(.article-detail-label){color:var(--text);font-weight:500}.article-detail-row .badge{width:fit-content}.article-detail-desc{margin:0;color:var(--text);white-space:pre-wrap;line-height:1.6;font-size:.9rem}.modal-detail .modal-footer{padding:1rem 1.5rem;margin-top:0}.modal-detail .modal-header{padding:1rem 1.5rem}.modal-footer--space-between{justify-content:space-between}.modal-footer-actions{display:flex;gap:.5rem;align-items:center}
