*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,sans-serif;line-height:1.5;color:#e8eaef;background:#0f1219}.shell{max-width:52rem;margin:0 auto;padding:2.5rem 1.25rem 4rem}.shell-narrow{max-width:28rem}.app-root{display:flex;min-height:100%}.sidebar{width:220px;flex-shrink:0;display:flex;flex-direction:column;background:#12161f;border-right:1px solid #252b38;padding:1rem 0}.sidebar-brand{padding:.35rem 1rem 1rem;font-weight:700;font-size:.95rem;letter-spacing:-.02em;color:#e8eaef;border-bottom:1px solid #252b38;margin-bottom:.75rem}.sidebar-nav{display:flex;flex-direction:column;gap:.15rem;padding:0 .6rem;flex:1}.nav-link{display:block;padding:.55rem .65rem;border-radius:8px;color:#9aa3b2;text-decoration:none;font-size:.95rem;font-weight:500}.nav-link:hover{color:#e8eaef;background:#1a2030}.nav-link-active{color:#e8eaef;background:#252d3d}.sidebar-footer{padding:.75rem .75rem 0;border-top:1px solid #252b38;margin-top:auto}.btn-block{width:100%;justify-content:center}.app-main{flex:1;min-width:0;overflow:auto}.page{max-width:56rem;padding:1.75rem 1.5rem 3rem}.page-header{margin-bottom:1.25rem}.page-header h1{margin:0 0 .35rem;font-size:1.35rem;font-weight:650;letter-spacing:-.02em}.page-card{margin-top:0}.page-card .h2{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:#c5ccd8}.list{margin:0;padding-left:1.25rem;color:#c5ccd8}.list li{margin-bottom:.4rem}.trends-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.trends-panel .h2{margin:0}.trends-lead{margin-top:.75rem}.table-wrap{overflow-x:auto;margin-top:1rem}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table th,.data-table td{padding:.5rem .65rem;text-align:left;border-bottom:1px solid #252b38;vertical-align:top}.data-table th{color:#9aa3b2;font-weight:600}.td-params{max-width:14rem;word-break:break-word}.td-actions{white-space:nowrap}.btn-link{background:none;border:none;color:#7c9cff;cursor:pointer;padding:.15rem .35rem;font-size:inherit}.btn-link:hover{text-decoration:underline}.btn-link-danger{color:#f87171}.badge{display:inline-block;padding:.15rem .45rem;border-radius:6px;font-size:.8rem;font-weight:600}.badge-on{background:#14532d;color:#86efac}.badge-off{background:#3f2e2e;color:#fca5a5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto}.modal-box{width:100%;max-width:28rem;background:#171c26;border:1px solid #2a3344;border-radius:12px;box-shadow:0 16px 48px #00000073}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.15rem;border-bottom:1px solid #252b38}.modal-title{margin:0;font-size:1.1rem;font-weight:650}.modal-close{background:none;border:none;color:#9aa3b2;font-size:1.5rem;line-height:1;cursor:pointer}.modal-close:hover{color:#e8eaef}.modal-form{padding:1rem 1.15rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.field-hint{margin:-.35rem 0 .35rem;font-size:.82rem;color:#7a8494}.form-row{display:flex;align-items:center}.check-label{display:flex;align-items:center;gap:.45rem;font-size:.95rem;color:#c5ccd8;cursor:pointer}.input-narrow{max-width:8rem}.textarea{resize:vertical;min-height:4rem;font-family:inherit}.modal-actions{display:flex;justify-content:flex-end;gap:.65rem;margin-top:.35rem}.header h1{margin:0 0 .35rem;font-size:1.5rem;font-weight:650;letter-spacing:-.02em}.muted{margin:0;color:#9aa3b2;font-size:.95rem}.card{margin-top:1.75rem;padding:1.25rem 1.35rem;border-radius:12px;background:#171c26;border:1px solid #252b38}.card p{margin:0 0 .75rem}.card p:last-child{margin-bottom:0}.header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.login-form{display:flex;flex-direction:column;gap:1rem;max-width:22rem}.label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;color:#c5ccd8}.input{padding:.55rem .65rem;border-radius:8px;border:1px solid #2a3344;background:#10151f;color:#e8eaef;font-size:1rem}.input:focus{outline:none;border-color:#4c6aed}.btn{padding:.55rem 1rem;border-radius:8px;border:none;background:#4c6aed;color:#fff;font-weight:600;cursor:pointer;font-size:.95rem}.btn:hover{filter:brightness(1.08)}.btn-ghost{background:transparent;border:1px solid #2a3344;color:#c5ccd8}.btn-ghost:hover{border-color:#4c6aed;color:#e8eaef}.error{margin:0;color:#f87171;font-size:.9rem}code{font-size:.9em;padding:.12em .35em;border-radius:6px;background:#222836}
