:root{--bg:#EFE5D6;--bg-deep:#F4ECE0;--surface:#FBF6EE;--surface-2:#F0E4D3;--surface-hover:#F0E4D3;--border:#E0CDB6;--border-soft:#D9C4AD;--text:#3A2A1E;--text-muted:#8A6F58;--text-faint:#A88B70;--sand:#E8D5C4;--header:#5D4037;--header-text:#FFF8EF;--header-text-muted:#E8D5C4;--primary:#7B3F32;--primary-hover:#9A5244;--primary-dark:#5C2F26;--secondary:#8A6F58;--secondary-light:#5C2F26;--gold:#C9A227;--gold-light:#F4D87E;--green:#1B5E20;--danger:#B91C1C;--danger-deep:#7f1d1d;--success:#15803D;--warning:#C2410C;--radius-sm:0.5rem;--radius:0.9rem;--radius-lg:1rem;--ring:0 0 0 2px #7B3F32;--transition:0.15s ease;--font-sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;--font-serif:Georgia,"Times New Roman",serif;--shweshwe:url(/shweshwe-dark.png)}:root[data-theme=dark]{--bg:#1A120B;--bg-deep:#140D07;--surface:#241A13;--surface-2:#2E2219;--surface-hover:#3A2B20;--border:#4A2D22;--border-soft:#38271D;--text:#F5EDE4;--text-muted:#C4A484;--text-faint:#8C7560;--sand:#EFE0CF;--header:#140D07;--header-text:#FFF8EF;--header-text-muted:#E8D5C4;--primary:#9A5244;--primary-hover:#B26354;--secondary:#C4A484;--secondary-light:#E2C9AE}:root[data-theme=dark] .badge-success{background:rgba(63,166,106,.18);color:#9BE3B8}:root[data-theme=dark] .badge-warning{background:rgba(224,138,60,.18);color:#F4C18A}:root[data-theme=dark] .badge-danger{background:rgba(214,69,60,.18);color:#F5A8A2}:root[data-theme=dark] .badge-info{background:rgba(120,160,220,.18);color:#BCD4F5}:root[data-theme=dark] .alert-error{background:rgba(214,69,60,.16);color:#F5A8A2;border-color:rgba(214,69,60,.4)}:root[data-theme=dark] .alert-success{background:rgba(63,166,106,.16);color:#9BE3B8;border-color:rgba(63,166,106,.4)}.theme-toggle{display:inline-flex;align-items:center;gap:.4rem;width:100%;background:rgba(42,26,16,.55);color:var(--header-text-muted);border:1px solid transparent;font-size:.85rem;font-weight:600}.theme-toggle:hover{background:rgba(42,26,16,.8);color:var(--header-text)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}::selection{background:rgba(201,162,39,.28);color:var(--text)}h1,h2,h3,h4{font-family:var(--font-sans);font-weight:700;line-height:1.25;color:var(--text)}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--primary-hover)}.btn,button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.2rem;border-radius:var(--radius-sm);border:1px solid transparent;font-family:inherit;font-size:.9375rem;font-weight:700;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition)}.btn:focus-visible,a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--primary);outline-offset:1px}.btn-primary{background:var(--primary);color:var(--sand)}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#cf3b32}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--sand);border-color:var(--border-soft)}.btn-emergency{background:var(--gold);color:#3A2A1E}.btn-emergency:hover{background:var(--gold-light)}input,select,textarea{width:100%;padding:.7rem .9rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);font-family:inherit;font-size:.9375rem;transition:border-color var(--transition),box-shadow var(--transition)}input::placeholder,textarea::placeholder{color:var(--text-faint)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring)}label{display:block;font-size:.78rem;font-weight:600;letter-spacing:.02em;margin-bottom:.4rem;color:var(--text-muted)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem}.badge{display:inline-flex;align-items:center;padding:.18rem .7rem;border-radius:9999px;font-size:.72rem;font-weight:700;letter-spacing:.02em}.badge-success{background:#DCFCE7;color:#166534}.badge-warning{background:#FEF3C7;color:#92400E}.badge-danger{background:#FEE2E2;color:#991B1B}.badge-info{background:#DBEAFE;color:#1E40AF}.grid-2{grid-template-columns:repeat(2,1fr);grid-gap:1rem}.grid-2,.grid-3{display:grid;gap:1rem}.grid-3{grid-template-columns:repeat(3,1fr);grid-gap:1rem}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:1rem;gap:1rem}@media (max-width:900px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.form-group{margin-bottom:1.1rem}table{width:100%;border-collapse:separate;border-spacing:0}td,th{padding:.8rem .9rem;text-align:left;border-bottom:1px solid var(--border)}thead th{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:700;background:var(--bg-deep)}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--bg-deep)}tbody tr:last-child td{border-bottom:none}.stat-card{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem 1.3rem}.stat-card:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--primary)}.stat-card h3{font-family:var(--font-sans);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.55rem}.stat-card .value{font-size:2rem;font-weight:700;line-height:1;color:var(--primary)}.layout-with-sidebar{display:flex;min-height:100vh}.sidebar{position:-webkit-sticky;position:sticky;top:0;width:260px;height:100vh;flex-shrink:0;padding:1.5rem .9rem;background-color:var(--header);overflow-y:auto}.sidebar h1{font-size:1.25rem;color:var(--header-text);margin-bottom:1.75rem;padding:0 .6rem}.sidebar nav a{display:flex;align-items:center;gap:.6rem;padding:.6rem .8rem;border-radius:var(--radius-sm);background:rgba(42,26,16,.55);color:var(--header-text-muted);font-size:.95rem;font-weight:500;margin-bottom:.18rem;transition:background var(--transition),color var(--transition)}.sidebar nav a:hover{background:rgba(42,26,16,.8);color:var(--header-text)}.sidebar nav a.active{background:var(--gold);color:#3A2A1E;font-weight:700}.nav-section-label{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-light);padding:1rem .8rem .4rem;margin-bottom:.1rem}.sidebar nav a.nav-sub{padding-left:1.4rem;font-size:.9rem}.main-content{flex:1 1;display:flex;flex-direction:column;overflow-x:auto;min-width:0;position:relative}.main-content-body{padding:2rem;flex:1 1}.main-content:before{content:"";position:fixed;inset:0;background-image:var(--shweshwe);background-size:340px;opacity:.05;pointer-events:none;z-index:0}.main-content-body{position:relative;z-index:1}.page-header{margin-bottom:1.75rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.page-header h2{font-size:1.5rem;margin-bottom:.25rem}.page-header p{color:var(--text-muted)}.alert{padding:.9rem 1.1rem;border-radius:var(--radius-sm);margin-bottom:1.1rem;font-size:.9rem;border:1px solid transparent}.alert-error{background:#FEE2E2;color:#991B1B;border-color:#f3b5b0}.alert-success{background:#DCFCE7;color:#166534;border-color:#a7e6bf}.login-page{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;overflow:hidden;background:radial-gradient(circle at 50% 30%,rgba(201,162,39,.18),transparent 55%),var(--bg)}.login-page:before{content:"";position:absolute;inset:0;background-image:var(--shweshwe);background-size:320px;opacity:.12;pointer-events:none;z-index:0}.login-card{position:relative;z-index:1;width:100%;max-width:420px;padding:2rem;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border)}.login-card h1{text-align:center;font-size:1.5rem;color:var(--primary);margin-bottom:.4rem}.login-card .subtitle{text-align:center;color:var(--text-muted);margin-bottom:1.75rem;font-size:.92rem}.ikitse-card h3{color:var(--primary);margin-bottom:.5rem}.ikitse-card p{color:var(--text-muted);font-size:.925rem}.ikitse-family-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));grid-gap:1rem;gap:1rem}.ikitse-family-card{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem;transition:border-color var(--transition)}.ikitse-family-card:hover{border-color:var(--primary)}.ikitse-family-card h4{color:var(--primary);margin-bottom:.4rem}.ikitse-family-card p{color:var(--text-muted);font-size:.9rem;line-height:1.5}.ikitse-go-ntho{font-size:1.2rem;font-weight:700;color:var(--primary);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.leboko-card{max-width:42rem}.leboko-header h3{color:var(--primary);margin-bottom:1.5rem;text-align:center}.leboko-poem{font-family:var(--font-serif);font-size:1rem;line-height:1.9;color:var(--text)}.leboko-stanza{margin:0 0 1.5rem}.leboko-stanza:last-child{margin-bottom:0;text-align:center;font-weight:700;color:var(--gold);font-size:1.15rem;letter-spacing:.05em}.leboko-line{display:inline}.map-panel{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;padding:.75rem;background:var(--surface)}.logo-brand{display:block;margin:0 auto 1.25rem;max-width:180px;height:auto}.sidebar .logo-brand{max-width:140px;margin-bottom:1.5rem}.panic-pulse{animation:bngpulse 1.5s infinite}@keyframes bngpulse{0%,to{opacity:1}50%{opacity:.55}}@media (max-width:768px){.main-content-body{padding:1.5rem 1.1rem}.sidebar{width:100%;height:auto;position:static}.layout-with-sidebar{flex-direction:column}}.mothusi-fab{position:fixed;right:1.25rem;bottom:1.25rem;z-index:60;width:56px;height:56px;border-radius:999px;background:var(--primary);color:var(--sand,#fff);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 26px rgba(0,0,0,.35);border:1px solid var(--border);cursor:pointer;transition:background var(--transition),transform var(--transition)}.mothusi-fab:hover{background:var(--primary-hover);transform:translateY(-2px)}.mothusi-panel{position:fixed;right:1.25rem;bottom:5.25rem;z-index:60;width:min(370px,calc(100vw - 2rem));height:min(560px,calc(100vh - 8rem));background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 24px 60px rgba(0,0,0,.4);display:flex;flex-direction:column;overflow:hidden}.mothusi-header{display:flex;align-items:center;gap:.6rem;padding:.9rem 1rem;background:var(--header,var(--primary-dark));border-bottom:1px solid var(--border)}.mothusi-title{color:var(--header-text,#fff);font-weight:700;font-size:.95rem}.mothusi-subtitle{color:var(--header-text-muted,var(--text-muted));font-size:.75rem}.mothusi-list{flex:1 1;overflow-y:auto;padding:.9rem;display:flex;flex-direction:column;gap:.55rem;background:var(--bg-deep)}.mothusi-msg{max-width:85%;padding:.55rem .8rem;border-radius:.85rem;font-size:.88rem;line-height:1.5;white-space:pre-line}.mothusi-msg.assistant{align-self:flex-start;background:var(--surface);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:.2rem}.mothusi-msg.user{align-self:flex-end;background:var(--primary);color:var(--sand,#fff);border-bottom-right-radius:.2rem}.mothusi-typing{opacity:.7;font-style:italic}.mothusi-confirm{display:flex;gap:.5rem;padding:.75rem;border-top:1px solid var(--border);background:var(--surface)}.mothusi-confirm button{flex:1 1}.mothusi-input-row{display:flex;gap:.5rem;padding:.75rem;border-top:1px solid var(--border);background:var(--surface)}.mothusi-input-row input{flex:1 1}.mothusi-input-row button{flex-shrink:0}@media (max-width:480px){.mothusi-panel{right:.6rem;bottom:4.6rem}.mothusi-fab{right:.6rem;bottom:.9rem}}.topbar{display:flex;align-items:center;gap:.5rem;padding:.7rem 1rem;border-bottom:1px solid var(--border);background:var(--surface);position:-webkit-sticky;position:sticky;top:0;z-index:15}.topbar-spacer{flex:1 1}.topbar-icon-btn,.topbar-item{position:relative;display:flex;align-items:center}.topbar-icon-btn{width:38px;height:38px;border-radius:999px;background:transparent;border:1px solid transparent;color:var(--text-muted);justify-content:center;cursor:pointer;transition:background var(--transition),color var(--transition)}.topbar-icon-btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--border)}.topbar-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 3px;background:var(--danger);color:#fff;font-size:.62rem}.topbar-avatar,.topbar-badge{border-radius:999px;font-weight:700;display:flex;align-items:center;justify-content:center}.topbar-avatar{width:38px;height:38px;background:var(--primary);color:var(--sand,#fff);font-size:.85rem;border:none;cursor:pointer}.topbar-avatar:hover{background:var(--primary-hover)}.topbar-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:260px;max-width:320px;max-height:360px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 16px 40px rgba(0,0,0,.3);padding:.6rem;z-index:40}.topbar-dropdown-title{font-weight:700;font-size:.85rem;padding:.2rem .4rem .5rem;color:var(--text)}.topbar-notification{padding:.5rem .4rem;border-radius:.4rem;cursor:pointer}.topbar-notification:hover{background:var(--surface-hover)}.topbar-notification.unread{background:var(--bg-deep)}.sidebar-footer{margin-top:auto;padding:1rem .6rem .2rem;font-size:.72rem;color:var(--text-faint,var(--text-muted))}