*{box-sizing:border-box;margin:0;padding:0}
html{color-scheme:light;background:#F4F6FA}
body{font-family:'Heebo',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;line-height:1.5;background:#F4F6FA;color:#1C2430;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:rgba(8,24,51,.08)}
:root{
  --navy-900:#081833;--navy-800:#0B1D3A;--navy-700:#122B52;--navy-600:#1A2F57;--navy-500:#243D6B;
  --accent:#F6A800;--accent-dark:#E09800;--accent-light:#FFF8E8;--accent-glow:rgba(246,168,0,.15);
  --bg-main:#F4F6FA;--card-bg:#FFFFFF;--border:#E4E8EF;--border-light:#F0F2F5;
  --text-main:#1C2430;--text-sec:#6B7A8D;--text-muted:#9BA5B7;
  --green:#24B36B;--green-bg:#EAFAF1;--green-border:#B7EBD0;
  --red:#E53E3E;--red-bg:#FFF5F5;--red-border:#FEB2B2;
  --blue:#3182CE;--blue-bg:#EBF8FF;--blue-border:#BEE3F8;
  --amber:#D69E2E;--amber-bg:#FFFFF0;--amber-border:#FEFCBF;
  --purple:#805AD5;--purple-bg:#FAF5FF;--purple-border:#E9D8FD;
  --radius:14px;--radius-sm:10px;--radius-lg:18px;--radius-xl:22px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.04);--shadow:0 2px 8px rgba(0,0,0,.06);--shadow-md:0 4px 16px rgba(0,0,0,.08);--shadow-lg:0 8px 32px rgba(0,0,0,.12);
  --transition:background-color .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1),opacity .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);
}

::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#D0D5DD;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#B0B8C4}
body.is-overlay-open{overflow:hidden}
button,a,[role="button"]{touch-action:manipulation}
h1,.shift-card h1,.page-title,.auth-hero-card h3,.auth-user-title strong,.modal-header h3,.osint-hero-title{text-wrap:balance}
.page-date,.shift-time-display,.stat-card .stat-value,.msg-time,.osint-item-time,.osint-source-mini,.row-num,.row-time{font-variant-numeric:tabular-nums}
.skip-link{position:fixed;top:12px;right:12px;transform:translateY(-180%);padding:10px 14px;border-radius:12px;background:var(--navy-900);color:#fff;text-decoration:none;font-size:.8rem;font-weight:700;box-shadow:var(--shadow-md);z-index:70}
.skip-link:focus-visible{transform:translateY(0)}
:focus-visible{outline:3px solid rgba(246,168,0,.45);outline-offset:3px}
button:focus:not(:focus-visible),a:focus:not(:focus-visible),input:focus:not(:focus-visible),select:focus:not(:focus-visible),textarea:focus:not(:focus-visible){outline:none}
.inp-invalid{border-color:var(--red)!important;box-shadow:0 0 0 3px rgba(229,62,62,.15)!important;background:#fff!important}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}

/* ===== SHIFT SELECT SCREEN ===== */
.shift-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;background:linear-gradient(135deg,var(--navy-900) 0%,#0D2243 40%,var(--navy-700) 100%);position:relative;overflow:hidden}
.shift-bg-pattern{position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(246,168,0,.06) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(49,130,206,.06) 0%,transparent 50%);pointer-events:none}
.shift-card{background:#fff;border-radius:var(--radius-xl);box-shadow:0 20px 60px rgba(0,0,0,.2);width:100%;max-width:460px;padding:36px;text-align:center;animation:fadeIn .5s ease;position:relative;z-index:1}
.shift-logo{width:76px;height:76px;margin:0 auto 16px;background:linear-gradient(135deg,var(--accent),#E89700);border-radius:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(246,168,0,.3)}
.shift-logo i{font-size:32px;color:#fff}
.shift-card h1{font-size:1.7rem;font-weight:900;color:var(--navy-900);margin-bottom:2px;letter-spacing:-.5px}
.shift-card .subtitle{color:var(--text-sec);font-size:.82rem;margin-bottom:12px}
.shift-time-display{font-size:2rem;font-weight:800;color:var(--navy-900);margin-bottom:16px;direction:ltr;font-variant-numeric:tabular-nums}
.shift-section-label{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.78rem;font-weight:700;color:var(--text-sec);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.shift-section-label i{color:var(--accent);font-size:.85rem}
.shift-divider{height:1px;background:var(--border);margin:18px 0}
.person-list{max-height:300px;overflow-y:auto;padding:4px}
.person-btn{display:flex;align-items:center;gap:12px;width:100%;padding:13px 16px;border:2px solid var(--border);border-radius:var(--radius);font-size:.88rem;font-weight:500;cursor:pointer;transition:var(--transition);background:#fff;text-align:right;font-family:'Heebo',sans-serif;color:var(--text-main);margin-bottom:6px}
.person-btn:hover{border-color:var(--accent);background:var(--accent-light)}
.person-btn.selected{border-color:var(--accent);background:linear-gradient(135deg,#FFF8E8,#FFFDF5);box-shadow:0 0 0 3px var(--accent-glow)}
.person-avatar{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:.88rem;flex-shrink:0;transition:var(--transition)}
.person-avatar.rav{background:linear-gradient(135deg,#FBBF24,#F59E0B);color:#fff;box-shadow:0 2px 8px rgba(245,158,11,.3)}
.person-avatar.cmd{background:linear-gradient(135deg,#A78BFA,#7C3AED);color:#fff}
.person-avatar.op{background:linear-gradient(135deg,#60A5FA,#3B82F6);color:#fff}
.person-info{flex:1;min-width:0}
.person-info .name{font-weight:600;font-size:.88rem}
.person-info .role-tag{font-size:.68rem;color:var(--accent);font-weight:700;background:var(--accent-light);padding:1px 8px;border-radius:10px;margin-right:6px}

.shift-type-group{display:flex;gap:6px;justify-content:center}
.shift-type-btn{flex:1;padding:12px 10px;border:2px solid var(--border);border-radius:var(--radius);font-size:.78rem;font-weight:600;cursor:pointer;transition:var(--transition);background:#fff;color:var(--text-sec);font-family:'Heebo',sans-serif;display:flex;flex-direction:column;align-items:center;gap:4px}
.shift-type-btn .shift-icon{font-size:1.2rem;margin-bottom:2px}
.shift-type-btn .shift-hours{font-size:.65rem;color:var(--text-muted);font-weight:400}
.shift-type-btn:hover{border-color:var(--accent);color:var(--accent)}
.shift-type-btn.active{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;border-color:var(--accent);box-shadow:0 4px 16px rgba(246,168,0,.3)}
.shift-type-btn.active .shift-hours{color:rgba(255,255,255,.8)}
.enter-btn{width:100%;margin-top:20px;background:linear-gradient(135deg,var(--accent),#D99000);color:#fff;font-weight:700;padding:15px;border-radius:var(--radius);border:none;cursor:pointer;font-size:.95rem;font-family:'Heebo',sans-serif;transition:var(--transition);box-shadow:0 4px 20px rgba(246,168,0,.25);display:flex;align-items:center;justify-content:center;gap:8px}
.enter-btn:hover{box-shadow:0 8px 30px rgba(246,168,0,.4);transform:translateY(-2px)}
.enter-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.auth-status-banner{display:none;padding:14px 16px;border-radius:16px;text-align:right;margin-bottom:16px;font-size:.82rem;line-height:1.7;border:1px solid var(--border)}
.auth-status-banner.is-error{display:block;background:var(--red-bg);border-color:var(--red-border);color:#8b1f1f}
.auth-status-banner.is-info{display:block;background:var(--blue-bg);border-color:var(--blue-border);color:#1f4b8b}
.auth-panel{display:grid;gap:14px;text-align:right}
.auth-hero-card{background:linear-gradient(180deg,#f7fbff 0%,#ffffff 100%);border:1px solid #dbe6f2;border-radius:20px;padding:18px 18px 16px;box-shadow:var(--shadow-sm)}
.auth-hero-card h3{font-size:1rem;font-weight:900;color:var(--navy-900);margin-bottom:6px}
.auth-hero-card p{font-size:.8rem;color:var(--text-sec);line-height:1.7}
.auth-grid{display:grid;gap:12px}
.auth-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 16px;border-radius:16px;border:1.5px solid #d7dee8;background:#fff;color:var(--text-main);font-size:.88rem;font-weight:800;font-family:'Heebo',sans-serif;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}
.auth-google-btn:hover{transform:translateY(-1px);border-color:#c3d4e8;box-shadow:var(--shadow)}
.auth-google-btn i{font-size:1rem;color:#db4437}
.auth-divider{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-form-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:18px;display:grid;gap:12px;box-shadow:var(--shadow-sm)}
.auth-form-title{display:flex;align-items:center;justify-content:space-between;gap:12px}
.auth-form-title strong{font-size:.94rem;color:var(--navy-900)}
.auth-form-title span{font-size:.72rem;color:var(--text-muted)}
.auth-inline-link{background:none;border:none;color:var(--blue);font:inherit;font-weight:800;cursor:pointer;padding:0}
.auth-inline-link:hover{text-decoration:underline}
.auth-actions{display:flex;gap:8px;flex-wrap:wrap}
.auth-actions .btn{flex:1}
.auth-footnote{font-size:.74rem;color:var(--text-muted);line-height:1.7}
.auth-user-card{background:linear-gradient(135deg,#fffaf0 0%,#ffffff 100%);border:1px solid #f4ddb1;border-radius:18px;padding:16px 18px;display:grid;gap:10px;text-align:right}
.auth-user-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.auth-user-title strong{display:block;font-size:1rem;color:var(--navy-900)}
.auth-user-title span{display:block;margin-top:4px;font-size:.78rem;color:var(--text-sec)}
.auth-chip-row{display:flex;flex-wrap:wrap;gap:8px}
.auth-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:var(--bg-main);font-size:.7rem;font-weight:800;color:var(--navy-800)}
.auth-post-actions{display:grid;gap:8px}
.auth-post-actions .btn{width:100%}
.auth-panel-loading{padding:28px 18px;border:1px dashed #d2dae6;border-radius:18px;text-align:center;color:var(--text-muted);font-size:.82rem}

/* ===== MAIN LAYOUT ===== */
#main-app{display:none;min-height:100vh;align-items:stretch}
#main-app.active{display:flex}
.sidebar{position:fixed;top:0;right:0;z-index:40;height:100vh;width:min(86vw,300px);max-width:300px;background:linear-gradient(180deg,var(--navy-900) 0%,#0A1930 40%,var(--navy-800) 100%);color:#fff;display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1);transform:translateX(100%);flex-shrink:0;overscroll-behavior:contain}
.sidebar.open{transform:translateX(0)}
@media(min-width:1024px){.sidebar{position:sticky;transform:translateX(0)!important;width:270px}}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:30;backdrop-filter:blur(2px);border:0;padding:0;cursor:pointer}
.sidebar-overlay.active{display:block}

.sidebar-header{padding:22px 20px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:14px}
.sidebar-logo{width:44px;height:44px;background:linear-gradient(135deg,var(--accent),#D99000);border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 16px rgba(246,168,0,.25)}
.sidebar-logo i{font-size:19px;color:#fff}
.sidebar-brand h2{font-size:.92rem;font-weight:800;line-height:1.3;letter-spacing:-.2px}
.sidebar-brand p{font-size:.65rem;color:rgba(255,255,255,.35);font-weight:400}

.sidebar nav{flex:1;padding:12px 10px;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:11px 14px;border:none;border-radius:var(--radius-sm);color:#7B8DA6;font-size:.84rem;font-weight:500;cursor:pointer;transition:var(--transition);background:transparent;text-align:right;font-family:'Heebo',sans-serif;margin-bottom:2px;position:relative}
.nav-item:hover{color:#C4D0E0;background:rgba(255,255,255,.05)}
.nav-item.active{color:var(--accent);background:rgba(246,168,0,.08);font-weight:700}
.nav-item.active::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:3px;background:var(--accent);border-radius:2px}
.nav-item i{width:20px;text-align:center;font-size:.88rem}
.nav-item span{flex:1}
.nav-badge{background:var(--red);color:#fff;font-size:.6rem;font-weight:700;padding:2px 7px;border-radius:10px;min-width:18px;text-align:center}
.nav-badge.hidden{display:none}
.nav-divider{height:1px;background:rgba(255,255,255,.05);margin:8px 14px}

.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.05)}
.sidebar-shift-info{padding:10px 12px;background:rgba(255,255,255,.04);border-radius:var(--radius-sm);margin-bottom:8px;font-size:.72rem;color:#7B8DA6;display:none}
.sidebar-shift-info.visible{display:block}
.sidebar-shift-info .shift-name{color:var(--accent);font-weight:700;font-size:.78rem}
.sidebar-footer{display:grid;gap:8px}
.sidebar-footer button{width:100%;padding:10px;border:none;background:rgba(255,255,255,.03);border-radius:var(--radius-sm);color:#5A6B80;font-size:.75rem;cursor:pointer;font-family:'Heebo',sans-serif;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:8px}
.sidebar-footer button:hover{background:rgba(239,68,68,.08);color:#EF4444}
#sign-out-btn{background:rgba(255,255,255,.05);color:#90a3bb}
#sign-out-btn:hover{background:rgba(49,130,206,.12);color:#bfd7f3}

/* ===== CONTENT AREA ===== */
.content-area{flex:1;min-height:100vh;display:flex;flex-direction:column;min-width:0}
.top-bar{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.95);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:14px 20px}
@media(min-width:1024px){.top-bar{padding:14px 28px}}
.top-bar-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.top-bar-right{display:flex;align-items:center;gap:10px}
.hamburger{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:none;background:transparent;color:var(--text-sec);cursor:pointer;border-radius:10px;font-size:1.1rem;transition:var(--transition)}
.hamburger:hover{background:var(--border-light);color:var(--text-main)}
@media(min-width:1024px){.hamburger{display:none}}
.page-title{font-size:1.4rem;font-weight:800;color:var(--text-main);letter-spacing:-.3px}
@media(min-width:1024px){.page-title{font-size:1.6rem}}
.page-date{font-size:.72rem;color:var(--text-muted);margin-top:1px}
.top-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.settlement-switcher{display:grid;gap:4px;min-width:min(260px,68vw)}
.settlement-switcher-label{font-size:.66rem;font-weight:800;color:var(--text-muted);padding-right:2px}
.settlement-switcher .inp{min-height:40px;background:#fff}
.btn-search-top{white-space:nowrap}
.btn-notifications-top{position:relative;white-space:nowrap}
.btn-notifications-top.has-unread{border-color:#f6a800;background:#fff8e8;color:#8a5a00}
.top-pill{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#c53030;color:#fff;font-size:.68rem;font-weight:800}

.btn-survey-top{display:none;align-items:center;gap:6px;background:linear-gradient(135deg,var(--accent),#D99000);color:#fff;font-weight:600;font-size:.78rem;padding:9px 18px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-family:'Heebo',sans-serif;transition:var(--transition);box-shadow:0 2px 10px rgba(246,168,0,.2)}
.btn-survey-top:hover{box-shadow:0 4px 20px rgba(246,168,0,.35);transform:translateY(-1px)}
.btn-survey-top:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}
@media(min-width:640px){.btn-survey-top{display:flex}}

.shift-badge{display:flex;align-items:center;gap:6px;padding:7px 16px;border-radius:30px;font-size:.75rem;font-weight:600;cursor:pointer;transition:var(--transition);border:2px solid;position:relative;background:#fff;text-align:right;font-family:'Heebo',system-ui,sans-serif}
.shift-badge-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.shift-badge.empty{border-color:var(--amber-border);background:var(--amber-bg);color:var(--amber)}
.shift-badge.empty .shift-badge-dot{background:var(--amber);animation:pulse 2s infinite}
.shift-badge.active{border-color:var(--green-border);background:var(--green-bg);color:var(--green)}
.shift-badge.active .shift-badge-dot{background:var(--green)}
.shift-badge:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ===== PAGES ===== */
.page-content{flex:1;padding:16px;overflow-x:hidden;min-width:0;width:100%}
@media(min-width:1024px){.page-content{padding:24px 30px;width:100%;max-width:1400px}}
.page{display:none;min-width:0}.page.active{display:block;animation:pageFade .25s ease}
@keyframes pageFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ===== CARDS ===== */
.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;transition:var(--transition);margin-bottom:16px}
.card:hover{box-shadow:var(--shadow)}
.card-sm{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;transition:var(--transition)}
.card-sm:hover{box-shadow:var(--shadow-sm)}
.card-accent{border-right:4px solid var(--accent)}
.card-success{border-right:4px solid var(--green)}
.card-danger{border-right:4px solid var(--red)}

/* ===== STAT CARDS ===== */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}
@media(min-width:640px){.stats-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.stats-grid{grid-template-columns:repeat(5,1fr)}}
.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;position:relative;overflow:hidden;transition:var(--transition);cursor:default}
.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.stat-card::after{content:'';position:absolute;top:0;right:0;bottom:0;width:4px;border-radius:0 4px 4px 0}
.stat-card.accent-orange::after{background:var(--accent)}
.stat-card.accent-red::after{background:var(--red)}
.stat-card.accent-green::after{background:var(--green)}
.stat-card.accent-blue::after{background:var(--blue)}
.stat-card.accent-purple::after{background:var(--purple)}
.stat-card .stat-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.stat-card .stat-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1rem}
.stat-card .stat-icon.orange{background:var(--accent-light);color:var(--accent)}
.stat-card .stat-icon.red{background:var(--red-bg);color:var(--red)}
.stat-card .stat-icon.green{background:var(--green-bg);color:var(--green)}
.stat-card .stat-icon.blue{background:var(--blue-bg);color:var(--blue)}
.stat-card .stat-icon.purple{background:var(--purple-bg);color:var(--purple)}
.stat-card .stat-value{font-size:1.9rem;font-weight:800;color:var(--text-main);line-height:1;font-variant-numeric:tabular-nums}
.stat-card .stat-label{font-size:.72rem;color:var(--text-sec);margin-top:4px;font-weight:500}
@media(max-width:640px){.stat-card .stat-value{font-size:1.4rem}.stat-card{padding:14px}}

/* ===== ALERT BANNER ===== */
.alert-banner{background:linear-gradient(90deg,#FFF3E0,#FFFAF0);border:1.5px solid #FFD180;border-radius:var(--radius);padding:14px 20px;display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;animation:fadeIn .4s ease}
.alert-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#FFE0B2,#FFCC80);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.alert-icon i{color:#BF360C;font-size:1rem}

/* ===== SECTION HEADERS ===== */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.section-title{font-size:1rem;font-weight:700;display:flex;align-items:center;gap:8px}
.section-title i{color:var(--accent)}

/* ===== BADGES ===== */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.65rem;font-weight:700;white-space:nowrap}
.badge-urgent{background:#FFF3E0;color:#BF360C;border:1px solid #FFCC80}
.badge-high{background:#FFF3E0;color:#E65100}
.badge-normal{background:#EBF8FF;color:#2B6CB0}
.badge-low{background:#F0FFF4;color:#276749}
.badge-critical{background:#FFF5F5;color:#C53030;border:1px solid #FEB2B2;animation:badgePulse 2s infinite}
.badge-ok{background:#F0FFF4;color:#276749}
.badge-fault{background:#FFF5F5;color:#C53030}
.badge-unchecked{background:#F7FAFC;color:#A0AEC0}
.badge-open{background:#FFF5F5;color:#C53030}
.badge-handling{background:#FFF3E0;color:#C05621}
.badge-closed{background:#F0FFF4;color:#276749}
.badge-pending{background:#FFF3E0;color:#C05621}
.badge-in_progress{background:#EBF8FF;color:#2B6CB0}
.badge-completed{background:#F0FFF4;color:#276749}
.badge-fighter{background:var(--blue-bg);color:var(--blue)}
.badge-ravshatz{background:var(--accent-light);color:var(--accent-dark)}
@keyframes badgePulse{0%,100%{opacity:1}50%{opacity:.7}}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition);border:none;font-family:'Heebo',sans-serif}
.btn-accent{background:linear-gradient(135deg,var(--accent),#D99000);color:#fff;box-shadow:0 2px 10px rgba(246,168,0,.2)}
.btn-accent:hover{box-shadow:0 4px 20px rgba(246,168,0,.35);transform:translateY(-1px)}
.btn-navy{background:linear-gradient(135deg,var(--navy-800),var(--navy-900));color:#fff}
.btn-navy:hover{box-shadow:var(--shadow-md)}
.btn-outline{background:#fff;color:var(--text-main);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.btn-danger:hover{background:#FED7D7}
.btn-success{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.btn-success:hover{background:#C6F6D5}
.btn-sm{padding:7px 14px;font-size:.76rem}
.btn-xs{padding:5px 10px;font-size:.7rem;border-radius:8px}
.btn-lg{padding:13px 28px;font-size:.88rem}
.btn-icon{width:34px;height:34px;padding:0;border-radius:10px;font-size:.85rem}
.btn-group{display:flex;gap:6px}

/* ===== FORM INPUTS ===== */
.inp{width:100%;padding:10px 14px;background:#F8FAFB;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Heebo',sans-serif;font-size:.85rem;color:var(--text-main);outline:none;transition:var(--transition)}
.inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:#fff}
.inp::placeholder{color:#B0B8C4}
select.inp{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7A8D' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 12px center;padding-left:32px}
textarea.inp{resize:vertical;min-height:60px}
.lbl{display:block;margin-bottom:4px;font-size:.75rem;font-weight:600;color:var(--text-sec)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ===== QUICK ACTIONS ===== */
.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}
@media(min-width:640px){.quick-actions{grid-template-columns:repeat(4,1fr)}}
.action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 12px;border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition);font-family:'Heebo',sans-serif;font-size:.78rem;font-weight:600;border:none}
.action-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.action-btn i{font-size:1.3rem}
.action-btn.primary{background:linear-gradient(135deg,var(--accent),#D99000);color:#fff;box-shadow:0 4px 16px rgba(246,168,0,.2)}
.action-btn.secondary{background:linear-gradient(135deg,var(--navy-700),var(--navy-900));color:#fff;box-shadow:0 4px 16px rgba(8,24,51,.2)}
.action-btn.light{background:#fff;color:var(--text-main);border:1.5px solid var(--border)}
.action-btn.light i{color:var(--text-sec)}
.action-btn.success{background:linear-gradient(135deg,#34D399,#059669);color:#fff;box-shadow:0 4px 16px rgba(5,150,105,.2)}
.action-btn.danger{background:linear-gradient(135deg,#f97316,#dc2626);color:#fff;box-shadow:0 4px 16px rgba(220,38,38,.18)}

/* ===== SURVEY ===== */
.survey-section{margin-bottom:20px}
.survey-section-title{font-weight:700;font-size:.88rem;padding:10px 16px;background:var(--bg-main);border-radius:var(--radius-sm) var(--radius-sm) 0 0;border:1px solid var(--border);border-bottom:none;display:flex;align-items:center;gap:8px}
.survey-section-title .count{font-size:.7rem;color:var(--text-muted);font-weight:500}
.survey-items{border:1px solid var(--border);border-radius:0 0 var(--radius-sm) var(--radius-sm);overflow:hidden;background:#fff}
.survey-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-light);transition:background .15s}
.survey-row:hover{background:#FAFBFC}
.survey-row:last-child{border-bottom:none}
.survey-row .item-name{font-size:.84rem;font-weight:600;color:var(--text-main)}
.survey-row .item-req{font-size:.7rem;color:var(--text-muted)}

.status-toggle{display:flex;gap:4px}
.status-opt{padding:5px 12px;border-radius:8px;font-size:.72rem;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--text-sec);transition:var(--transition);font-family:'Heebo',sans-serif}
.status-opt:hover{border-color:var(--text-muted)}
.status-opt.s-ok{border-color:var(--green);background:var(--green-bg);color:var(--green)}
.status-opt.s-fault{border-color:var(--red);background:var(--red-bg);color:var(--red)}

.notes-input{padding:5px 10px;border:1.5px solid var(--border);border-radius:8px;font-size:.75rem;font-family:'Heebo',sans-serif;color:var(--text-main);outline:none;transition:border .2s;background:#F8FAFB;width:90px}
.notes-input:focus{border-color:var(--accent);background:#fff}
@media(min-width:640px){.notes-input{width:140px}}

.cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dot-communication{background:#3B82F6}.dot-surveillance{background:#8B5CF6}.dot-weapons{background:#EF4444}.dot-drones{background:#06B6D4}.dot-general_equipment{background:#10B981}.dot-maintenance{background:#6366F1}

/* ===== TIMELINE ===== */
.tl-item{position:relative;padding-right:24px;padding-bottom:16px;border-right:2px solid var(--border)}
.tl-item::before{content:'';position:absolute;right:-5px;top:6px;width:8px;height:8px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 3px var(--accent-light)}
.tl-item:last-child{border-color:transparent}

/* ===== TOAST ===== */
.toast-container{position:fixed;bottom:20px;left:20px;z-index:60;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:10px;padding:12px 20px;border-radius:var(--radius);font-size:.85rem;font-weight:500;animation:slideUp .3s ease;box-shadow:var(--shadow-md)}
.toast-success{background:var(--green-bg);color:#166534;border:1px solid var(--green-border)}
.toast-error{background:var(--red-bg);color:#991B1B;border:1px solid var(--red-border)}
.toast-info{background:var(--blue-bg);color:#1E40AF;border:1px solid var(--blue-border)}
@keyframes slideUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes fadeIn{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}

/* ===== MODAL ===== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:50;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px);overscroll-behavior:contain}
.modal-overlay.active{display:flex}
.modal-box{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px rgba(0,0,0,.2);animation:fadeIn .2s ease}
.modal-header{padding:22px 24px 0;display:flex;align-items:center;justify-content:space-between}
.modal-header h3{font-size:1.1rem;font-weight:800}
.modal-close{width:34px;height:34px;border:none;background:var(--bg-main);border-radius:10px;cursor:pointer;color:var(--text-sec);display:flex;align-items:center;justify-content:center;transition:var(--transition);font-size:.9rem}
.modal-close:hover{background:var(--red-bg);color:var(--red)}
.modal-body{padding:18px 24px 26px}

/* ===== DASHBOARD ===== */
.dash-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:4px}
@media(min-width:768px){.dash-grid{grid-template-columns:1fr 1fr}}
.dashboard-attention-card{border-color:#ffe2ad;background:linear-gradient(180deg,#fffaf0 0%,#ffffff 100%)}
.dashboard-attention-list{display:grid;gap:10px}
.attention-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:16px;background:#fff;cursor:pointer;text-align:right;font-family:'Heebo',sans-serif;transition:var(--transition)}
.attention-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:#d8dee7}
.attention-item-copy{display:grid;gap:4px;flex:1;min-width:0}
.attention-item-copy strong{font-size:.84rem;color:var(--navy-900);line-height:1.5;word-break:break-word}
.attention-item-copy span{font-size:.74rem;color:var(--text-sec);line-height:1.6}
.attention-item-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.attention-critical .attention-item-icon{background:var(--red-bg);color:var(--red)}
.attention-high .attention-item-icon{background:#fff3e0;color:#c05621}
.attention-normal .attention-item-icon{background:var(--blue-bg);color:var(--blue)}

.quick-search-results{display:grid;gap:8px;min-height:120px}
.quick-search-empty{display:grid;place-items:center;gap:8px;padding:28px 16px;border:1px dashed var(--border);border-radius:16px;background:var(--bg-main);text-align:center;color:var(--text-muted)}
.quick-search-empty i{font-size:1.05rem;color:var(--text-sec)}
.quick-search-item{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:16px;background:#fff;cursor:pointer;text-align:right;font-family:'Heebo',sans-serif;transition:var(--transition)}
.quick-search-item:hover{border-color:#d7dfea;box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.quick-search-copy{display:grid;gap:4px;flex:1;min-width:0}
.quick-search-copy strong{font-size:.84rem;color:var(--navy-900);line-height:1.5;word-break:break-word}
.quick-search-copy span{font-size:.74rem;color:var(--text-sec);line-height:1.6}
.quick-search-meta{display:grid;gap:6px;justify-items:end;flex-shrink:0;font-size:.68rem;color:var(--text-muted)}
@media(max-width:640px){.quick-search-item{flex-direction:column}.quick-search-meta{justify-items:start}}

.notifications-list{display:grid;gap:10px}
.notification-item{display:grid;gap:10px;padding:14px 16px;border:1px solid var(--border);border-radius:16px;background:#fff}
.notification-item.notification-critical{border-color:#fecaca;background:linear-gradient(180deg,#fff7f7 0%,#fff 100%)}
.notification-item.notification-high{border-color:#fed7aa;background:linear-gradient(180deg,#fffaf4 0%,#fff 100%)}
.notification-item.is-read{opacity:.82}
.notification-main{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.notification-copy{display:grid;gap:6px;flex:1;min-width:0}
.notification-copy strong{font-size:.88rem;color:var(--navy-900)}
.notification-copy span{font-size:.76rem;color:var(--text-sec);line-height:1.7}
.notification-meta{font-size:.7rem;color:var(--text-muted);white-space:nowrap}
.notification-actions{display:flex;gap:6px;flex-wrap:wrap}

.report-section{display:grid;gap:14px}
.report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.report-card{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;padding:16px;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,#fff 0%,#fafcff 100%)}
.report-card.compact{padding:14px}
.report-card-icon{width:42px;height:42px;border-radius:14px;background:var(--bg-main);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1rem}
.report-card-copy{display:grid;gap:6px;min-width:0}
.report-card-copy strong{font-size:.86rem;color:var(--navy-900)}
.report-card-copy span{font-size:.75rem;color:var(--text-sec);line-height:1.7}
.report-card-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;grid-column:1 / -1}

.attachment-upload-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.attachment-list{display:grid;gap:10px}
.attachment-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:14px;background:#fff}
.attachment-main{display:flex;align-items:center;gap:10px;min-width:0}
.attachment-icon{width:36px;height:36px;border-radius:12px;background:var(--bg-main);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}
.attachment-copy{display:grid;gap:4px;min-width:0}
.attachment-copy strong{font-size:.82rem;color:var(--navy-900);word-break:break-word}
.attachment-copy span{font-size:.72rem;color:var(--text-muted);line-height:1.6}
.attachment-actions{display:flex;gap:6px;flex-wrap:wrap;flex-shrink:0}

.signature-pad-field{display:grid;gap:8px}
.signature-pad-canvas{width:100%;min-height:150px;border:1.5px dashed #cdd6e1;border-radius:14px;background:#fff;touch-action:none}
.signature-pad-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}

.armory-warning{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);font-size:.78rem;line-height:1.7;background:#fff}
.armory-warning.is-ok{border-color:#bbf7d0;background:#f0fff4;color:#166534}
.armory-warning.is-high{border-color:#fed7aa;background:#fffaf0;color:#9a3412}
.armory-warning.is-critical{border-color:#fecaca;background:#fff5f5;color:#991b1b}

/* ===== OPERATIONAL MODULES ===== */
.operational-module-stack{display:grid;gap:16px}
.operational-module-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 18px 16px;box-shadow:var(--shadow-sm)}
.operational-module-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}
.operational-record{display:grid;gap:12px;border:1px solid var(--border);border-radius:16px;padding:14px;background:linear-gradient(180deg,#fff 0%,#fafcff 100%);min-width:0;transition:var(--transition)}
.operational-record:hover{box-shadow:var(--shadow);border-color:#d4dbe6}
.operational-record-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.operational-record-title{font-size:.9rem;font-weight:900;color:var(--navy-900);line-height:1.5;word-break:break-word}
.operational-record-subtitle{font-size:.75rem;color:var(--text-muted);margin-top:4px}
.operational-meta-list{display:flex;flex-wrap:wrap;gap:6px}
.operational-meta-item{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;background:var(--bg-main);font-size:.68rem;font-weight:700;color:var(--text-sec)}
.operational-meta-item strong{color:var(--text-main)}
.operational-record-body{font-size:.78rem;line-height:1.75;color:var(--text-sec);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.operational-actions{display:flex;gap:6px;flex-wrap:wrap}
.operational-section-help{font-size:.74rem;color:var(--text-muted);margin-top:-4px;margin-bottom:12px;line-height:1.7}
.operational-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:18px}
@media(min-width:900px){.operational-stat-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}

/* ===== OSINT ===== */
.osint-hero{position:relative;overflow:hidden;background:
  radial-gradient(circle at top right,rgba(49,130,206,.12),transparent 34%),
  radial-gradient(circle at top left,rgba(246,168,0,.12),transparent 28%),
  linear-gradient(180deg,#ffffff 0%,#f8fbff 100%)}
.osint-hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap}
.osint-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:rgba(8,24,51,.06);color:var(--navy-800);font-size:.74rem;font-weight:700;margin-bottom:14px}
.osint-eyebrow i{color:var(--accent)}
.osint-hero-title{font-size:1.5rem;font-weight:900;letter-spacing:-.5px;color:var(--navy-900);line-height:1.2}
.osint-hero-text{max-width:760px;margin-top:10px;font-size:.9rem;line-height:1.75;color:var(--text-sec)}
.osint-hero-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.osint-meta-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-top:22px}
.osint-meta-card{padding:16px 18px;border-radius:16px;border:1px solid rgba(8,24,51,.08);background:rgba(255,255,255,.82);backdrop-filter:blur(8px);min-width:0}
.osint-meta-label{display:block;font-size:.72rem;font-weight:700;color:var(--text-muted);margin-bottom:8px}
.osint-meta-card strong{display:block;font-size:1.18rem;font-weight:900;color:var(--navy-900);line-height:1.2}
.osint-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:16px;align-items:start}
.osint-main-column,.osint-side-column{min-width:0}
.osint-bullet-list,.osint-section-list,.osint-source-list,.osint-tools-list{display:grid;gap:10px}
.osint-bullet-row{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:16px;border:1px solid var(--border);background:#fff;text-decoration:none;color:inherit;transition:var(--transition);min-width:0}
.osint-bullet-row:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:#cfd9e6}
.osint-bullet-dot{width:11px;height:11px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#d99000);box-shadow:0 0 0 6px rgba(246,168,0,.12);flex-shrink:0;margin-top:9px}
.osint-bullet-copy{flex:1;min-width:0}
.osint-bullet-title{font-size:.9rem;font-weight:800;color:var(--text-main);line-height:1.55;word-break:break-word}
.osint-bullet-meta{margin-top:6px;font-size:.74rem;color:var(--text-muted);line-height:1.5}
.osint-item-card{padding:16px;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,#ffffff 0%,#fbfcfe 100%);min-width:0}
.osint-item-card.compact{padding:14px}
.osint-item-top{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.osint-item-time{font-size:.72rem;color:var(--text-muted);font-weight:600}
.osint-item-card h4{font-size:.94rem;font-weight:800;line-height:1.55;color:var(--navy-900);word-break:break-word}
.osint-item-card p{margin-top:10px;font-size:.82rem;line-height:1.75;color:var(--text-sec);display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.osint-item-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:14px;padding-top:12px;border-top:1px solid var(--border-light);font-size:.74rem;color:var(--text-muted)}
.osint-item-footer a{color:var(--blue);font-weight:700;text-decoration:none}
.osint-item-footer a:hover{text-decoration:underline}
.osint-sheet-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:10px}
.osint-sheet-card{padding:14px;border-radius:16px;border:1px solid var(--border);background:#fff}
.osint-sheet-card strong{display:block;font-size:.86rem;color:var(--navy-900)}
.osint-sheet-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px;font-size:.74rem;color:var(--text-sec)}
.osint-source-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:16px;background:#fff;min-width:0}
.osint-source-row.is-ok{border-color:var(--green-border);background:linear-gradient(180deg,#ffffff 0%,#f4fff8 100%)}
.osint-source-row.is-error{border-color:var(--red-border);background:linear-gradient(180deg,#ffffff 0%,#fff8f8 100%)}
.osint-source-row.is-pending{border-color:var(--amber-border);background:linear-gradient(180deg,#ffffff 0%,#fffdf2 100%)}
.osint-source-row.is-reference{border-color:var(--border);background:linear-gradient(180deg,#ffffff 0%,#fbfcfe 100%)}
.osint-source-main,.osint-source-side{min-width:0}
.osint-source-main{flex:1}
.osint-source-name{font-size:.84rem;font-weight:800;color:var(--text-main);word-break:break-word}
.osint-source-meta{margin-top:4px;font-size:.73rem;color:var(--text-muted);line-height:1.5}
.osint-source-side{display:flex;flex-direction:column;align-items:flex-end;gap:6px;text-align:left;flex-shrink:0}
.osint-source-side a{font-size:.74rem;font-weight:700;color:var(--blue);text-decoration:none}
.osint-source-side a:hover{text-decoration:underline}
.osint-source-mini{font-size:.69rem;color:var(--text-muted)}
.osint-source-error{margin-top:-2px;padding:0 16px 12px;font-size:.72rem;line-height:1.6;color:#b83232}
.osint-tool-card{display:block;padding:14px 16px;border:1px solid var(--border);border-radius:16px;background:#fff;text-decoration:none;color:inherit;transition:var(--transition)}
.osint-tool-card:hover{border-color:#cfd9e6;box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.osint-tool-card strong{display:block;font-size:.84rem;color:var(--navy-900)}
.osint-tool-card span{display:inline-block;margin-top:6px;font-size:.7rem;font-weight:700;color:var(--accent-dark);background:var(--accent-light);padding:4px 10px;border-radius:999px}
.osint-tool-card p{margin-top:10px;font-size:.78rem;line-height:1.65;color:var(--text-sec)}
@media(min-width:680px){
  .osint-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .osint-sheet-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(min-width:1100px){
  .osint-layout{grid-template-columns:minmax(0,1.55fr) minmax(320px,.95fr)}
  .osint-meta-grid{grid-template-columns:repeat(5,minmax(0,1fr))}
  .osint-sheet-grid{grid-template-columns:minmax(0,1fr)}
}
@media(max-width:1023px){
  .osint-layout{grid-template-columns:minmax(0,1fr)}
}
@media(max-width:640px){
  .osint-hero-title{font-size:1.22rem}
  .osint-hero-text{font-size:.84rem}
  .osint-hero-actions{width:100%}
  .osint-hero-actions .btn{flex:1}
  .osint-meta-card strong{font-size:1.03rem}
  .osint-item-card,
  .osint-bullet-row,
  .osint-source-row,
  .osint-tool-card,
  .osint-sheet-card{padding:13px}
  .osint-source-row{flex-direction:column}
  .osint-source-side{align-items:flex-start;text-align:right}
  .osint-item-footer{flex-direction:column;align-items:flex-start}
}
.faults-panel{position:relative}
.faults-ok{text-align:center;padding:28px 20px}
.faults-ok i{font-size:2.8rem;color:var(--green);margin-bottom:8px;display:block}
.faults-ok p{font-size:.9rem;font-weight:600;color:var(--green)}

.highlights-list{max-height:220px;overflow-y:auto}
.hl-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);margin-bottom:6px;transition:background .15s}
.hl-item.urgent{background:linear-gradient(90deg,#FFF8E8,#FFFDF5);border:1px solid #FFE5A0}
.hl-item.normal{background:var(--bg-main)}
.hl-item .hl-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.hl-item .hl-dot.critical{background:var(--red)}
.hl-item .hl-dot.high{background:var(--accent)}
.hl-item .hl-dot.normal{background:var(--blue)}
.hl-item .hl-text{font-size:.82rem;font-weight:500;flex:1;min-width:0}

/* ===== OPERATIONS LOG ===== */
.op-card{border-radius:var(--radius);border:1px solid var(--border);padding:16px;background:#fff;transition:var(--transition);margin-bottom:10px}
.op-card:hover{box-shadow:var(--shadow-sm)}
.op-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.op-details{display:flex;gap:16px;flex-wrap:wrap;font-size:.75rem;color:var(--text-sec);margin-top:8px}
.op-details span{display:flex;align-items:center;gap:4px}

/* ===== SHIFT SCHEDULE ===== */
.shift-table{width:100%;text-align:center;border-collapse:separate;border-spacing:0}
.shift-table th{font-size:.72rem;color:var(--text-sec);font-weight:600;padding:8px 4px;border-bottom:2px solid var(--border)}
.shift-table td{padding:4px}
.shift-cell{padding:8px 4px;border-radius:8px;font-size:.72rem;cursor:pointer;transition:var(--transition);font-weight:500}
.shift-cell.filled{background:var(--accent-light);color:var(--accent-dark);font-weight:600;border:1px solid rgba(246,168,0,.2)}
.shift-cell.empty{background:var(--bg-main);color:var(--text-muted)}
.shift-cell.weekend{background:#F0EBF8;color:#6B21A8}
.shift-cell.weekend.filled{background:#EDE9FE;color:#7C3AED;border-color:rgba(124,58,237,.2)}
.shift-cell:hover{box-shadow:var(--shadow-sm);transform:scale(1.03)}
.shift-row-label{font-size:.75rem;font-weight:700;color:var(--text-sec);padding:8px;white-space:nowrap}
.shift-person{font-size:.74rem;font-weight:700;line-height:1.25;min-height:18px}
.shift-slot-time{font-size:.62rem;color:inherit;opacity:.82;margin-top:4px}

/* ===== PERSON CARD ===== */
.person-card{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:var(--transition)}
.person-card:hover{box-shadow:var(--shadow-sm);border-color:var(--accent)}

/* ===== EQUIPMENT GROUP ===== */
.equip-group{margin-bottom:20px}
.equip-group-header{font-weight:700;font-size:.9rem;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.equip-group-header .ecount{font-size:.72rem;color:var(--text-muted);font-weight:400}
.equip-list{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.equip-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-light);transition:background .15s}
.equip-item:last-child{border-bottom:none}
.equip-item:hover{background:#FAFBFC}

/* ===== FOOTER INFO ===== */
.last-check-footer{background:var(--bg-main);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;text-align:center;font-size:.75rem;color:var(--text-sec);margin-bottom:16px}
.last-check-footer b{color:var(--text-main)}

/* ===== MESSAGES ===== */
.msg-item{display:flex;gap:10px;padding:14px;border-bottom:1px solid var(--border-light)}
.msg-item:last-child{border-bottom:none}
.msg-avatar{width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0;background:var(--blue-bg);color:var(--blue)}
.msg-avatar.rav{background:var(--accent-light);color:var(--accent)}
.msg-content{flex:1;min-width:0}
.msg-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.msg-name{font-size:.82rem;font-weight:700;color:var(--text-main)}
.msg-time{font-size:.68rem;color:var(--text-muted)}
.msg-text{font-size:.85rem;color:var(--text-sec);line-height:1.5}
.message-target-chip{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:5px 10px;border-radius:999px;background:#eefbf3;color:#1f7a45;font-size:.68rem;font-weight:600;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ===== SETTINGS ===== */
.settings-group{margin-bottom:24px}
.settings-group-title{font-size:.9rem;font-weight:700;color:var(--text-main);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.settings-group-title i{color:var(--accent)}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-light)}
.settings-row:last-child{border-bottom:none}
.settings-label{font-size:.85rem;font-weight:500;color:var(--text-main)}
.settings-desc{font-size:.72rem;color:var(--text-muted)}

/* ===== TRANSITION OVERLAY ===== */
.transition-overlay{position:fixed;inset:0;z-index:55;background:rgba(8,24,51,.9);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:16px;overflow-y:auto;overscroll-behavior:contain}
.transition-card{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:520px;padding:32px;animation:fadeIn .4s ease;max-height:90vh;overflow-y:auto}
.transition-header{text-align:center;margin-bottom:20px}
.transition-icon{width:64px;height:64px;margin:0 auto 14px;background:linear-gradient(135deg,var(--accent),#D99000);border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(246,168,0,.3)}
.transition-icon i{font-size:24px;color:#fff}
.transition-header h2{font-size:1.5rem;font-weight:900;color:var(--navy-900);margin-bottom:4px}
.transition-header .subtitle{font-size:.82rem;color:var(--text-sec)}
.transition-alert{display:flex;align-items:flex-start;gap:12px;background:linear-gradient(90deg,#FFF3E0,#FFFAF0);border:1.5px solid #FFD180;border-radius:var(--radius);padding:14px 16px;margin-bottom:20px}
.transition-alert i{font-size:1.3rem;color:var(--accent);flex-shrink:0;margin-top:2px}
.transition-alert strong{color:#BF360C;font-size:.85rem;display:block;margin-bottom:2px}
.transition-alert p{font-size:.78rem;color:#E65100;line-height:1.5}
.transition-section{margin-bottom:16px}
.transition-check{padding:14px 16px;background:var(--bg-main);border-radius:var(--radius);margin-bottom:16px}
.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.82rem;color:var(--text-main);font-weight:500}
.checkbox-label input[type="checkbox"]{display:none}
.checkbox-label .checkmark{width:24px;height:24px;border:2px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition);color:transparent}
.checkbox-label input:checked+.checkmark{background:var(--green);border-color:var(--green);color:#fff}

/* ===== GREETING BANNER ===== */
.greeting-card{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#E8F5E9,#F1F8E9);border:1.5px solid #A5D6A7;border-radius:var(--radius);padding:16px 18px;margin-bottom:18px;animation:fadeIn .3s ease}
.greeting-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#4CAF50,#43A047);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px rgba(76,175,80,.3)}
.greeting-icon i{font-size:20px;color:#fff}
.greeting-content{flex:1;min-width:0}
.greeting-content h3{font-size:1rem;font-weight:800;color:#1B5E20;margin-bottom:2px}
.greeting-content p{font-size:.78rem;color:#2E7D32;line-height:1.4}
.greeting-actions{display:flex;gap:6px;flex-shrink:0;flex-wrap:wrap}
@media(max-width:480px){
  .greeting-card{flex-direction:column;text-align:center}
  .greeting-actions{justify-content:center;width:100%}
}

/* ===== UPLOAD ZONE ===== */
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:32px 16px;text-align:center;cursor:pointer;transition:var(--transition);background:var(--bg-main)}
.upload-zone:hover{border-color:var(--accent);background:var(--accent-light)}
.upload-zone.drag-over{border-color:var(--accent);background:var(--accent-light);transform:scale(1.01)}

/* ===== TASK + SURVEY ENHANCEMENTS ===== */
.task-highlight-card{background:linear-gradient(135deg,#fff8e8,#fffdf5);border-color:#ffe2a3}
.survey-photo-preview{display:block;max-width:140px;max-height:120px;border-radius:10px;border:1px solid var(--border);object-fit:cover;background:#fff}

/* ===== SPINNER ===== */
.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;margin:0 auto;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== RESPONSIVE ===== */
@media(max-width:640px){
  .shift-card{padding:28px 22px}
  .top-bar{padding:12px 14px}
  .top-bar-inner{flex-direction:column;align-items:stretch}
  .top-bar-right{justify-content:space-between}
  .top-actions{gap:8px;width:100%;display:grid;grid-template-columns:1fr}
  .btn-survey-top{display:flex;justify-content:center;width:100%}
  .top-actions{gap:6px}
  .shift-badge{font-size:.7rem;padding:8px 12px;width:100%;justify-content:center}
  .card{padding:16px;border-radius:var(--radius)}
  .page-title{font-size:1.15rem}
  .action-btn{padding:16px 8px;font-size:.72rem}
  .action-btn i{font-size:1.1rem}
  .notification-main,.attachment-item{flex-direction:column;align-items:flex-start}
  .notification-meta{white-space:normal}
  .report-card{grid-template-columns:1fr}
  .survey-row{padding:10px 12px;gap:8px;flex-wrap:wrap}
  .status-toggle{order:3;width:100%;justify-content:flex-end}
  .notes-input{order:4;width:100%}
  .form-row{grid-template-columns:1fr}
  .transition-card{padding:20px}
  .modal-overlay{padding:12px}
  .modal-box{max-width:100%;max-height:calc(100vh - 24px);border-radius:18px}
  .modal-header{padding:18px 18px 0}
  .modal-body{padding:16px 18px 20px}
  .auth-user-top,.auth-form-title{flex-direction:column;align-items:flex-start}
  .toast-container{left:12px;right:12px;bottom:12px}
  .toast{width:100%}
}

/* Helpers */
.space-y-3>*+*{margin-top:12px}
.text-center{text-align:center}
.text-muted{color:var(--text-muted)}
.hidden{display:none!important}
.progress-bar{height:6px;background:var(--border);border-radius:4px;overflow:hidden;margin-top:8px}
.progress-bar .fill{height:100%;border-radius:4px;transition:width .5s ease}
.progress-bar .fill.green{background:linear-gradient(90deg,#34D399,#059669)}
.progress-bar .fill.orange{background:linear-gradient(90deg,var(--accent),#D99000)}
.progress-bar .fill.red{background:linear-gradient(90deg,#F87171,#DC2626)}
.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}
.empty-state i{font-size:2.5rem;color:var(--border);display:block;margin-bottom:10px}
.empty-state p{font-size:.88rem}

/* Operations Logbook */
.ops-logbook{background:#fff;border-radius:14px;border:1px solid var(--border);overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.logbook-header{text-align:center;padding:16px 20px;background:linear-gradient(135deg,#1a365d,#2d4a7c);color:#fff}
.logbook-title{font-size:1.05rem;font-weight:800;letter-spacing:-.3px}
.logbook-title i{margin-left:6px}
.logbook-subtitle{font-size:.75rem;color:#cbd5e0;margin-top:4px}
.logbook-table{width:100%;border-collapse:collapse;font-size:.78rem}
.logbook-table th{background:#edf2f7;color:#2d3748;padding:8px 6px;font-weight:600;text-align:right;border:1px solid #e2e8f0;font-size:.72rem;white-space:nowrap}
.logbook-table td{padding:6px;border:1px solid #e2e8f0;vertical-align:top}
.logbook-table tbody tr:nth-child(even){background:#f7fafc}
.logbook-table tbody tr:hover{background:#edf2f7}
.logbook-row.severity-critical td{background:#fff5f5!important;border-right:3px solid #e53e3e}
.logbook-row.severity-high td{background:#fffaf0!important;border-right:3px solid #dd6b20}
.row-num{text-align:center;font-weight:700;color:#4a5568;font-size:.75rem}
.row-time{font-size:.75rem;color:#4a5568;white-space:nowrap}
.logbook-footer{display:flex;justify-content:space-between;padding:8px 14px;border-top:1px solid #e2e8f0;font-size:.72rem;color:#718096;background:#f7fafc}
.ops-template-page{width:100%;max-width:279mm;margin:0 auto;padding:0;background:linear-gradient(180deg,#f4f7fb 0%,#ffffff 18%,#f4f7fb 100%)}
.ops-logbook-template{border-radius:16px;overflow:hidden}
.logbook-header-template{padding:12px 18px 10px}
.logbook-template-meta{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:8px 12px;background:#f8fafc;border-bottom:1px solid #dbe4f0}
.template-meta-card{background:rgba(255,255,255,.92);border:1px solid #dbe4f0;border-radius:12px;padding:7px 9px;min-height:52px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.template-meta-label{font-size:.67rem;font-weight:800;color:#1f3f6c;letter-spacing:.02em}
.template-meta-line{height:18px;border-bottom:1.5px dashed #9aaec8}
.logbook-template-table-wrap{overflow:hidden}
.logbook-template-table th{font-size:.69rem;letter-spacing:.01em;background:#e8eef7}
.logbook-template-table tbody tr:nth-child(even),
.logbook-template-table tbody tr:hover{background:transparent}
.logbook-template-row td{padding:0;height:12.6mm;vertical-align:top;background:#fff}
.logbook-template-row .row-num{background:linear-gradient(180deg,#f8fafc,#eef2f7);font-size:.8rem;font-weight:800}
.template-row-number{vertical-align:middle!important}
.template-cell{position:relative}
.template-writing-lines{height:100%;width:100%;background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 4mm,rgba(62,95,136,.18) 4mm,rgba(62,95,136,.18) 4.3mm);background-position:center 2.7mm;background-size:100% 4.3mm}
.template-cell-compact .template-writing-lines{background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 4.3mm,rgba(62,95,136,.16) 4.3mm,rgba(62,95,136,.16) 4.55mm);background-size:100% 4.55mm}
.template-cell-wide .template-writing-lines{background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 3.7mm,rgba(62,95,136,.2) 3.7mm,rgba(62,95,136,.2) 4mm);background-size:100% 4mm}
.logbook-template-footer{padding:7px 12px;background:linear-gradient(180deg,#f8fbff,#eff4fb);font-weight:600;color:#47607f}
.ops-template-render-root{position:fixed;left:-200vw;top:-200vh;width:279mm;pointer-events:none;z-index:-1}
.ops-template-print-page{background:#f4f7fb;margin:0;padding:8mm}

/* Pinned Messages */
.msg-pinned{background:linear-gradient(135deg,#fffbeb,#fef3c7)!important;border-right:3px solid var(--accent)}
.msg-pinned .msg-meta{color:#92400e}

/* Print Styles */
@media print{
  .no-print,.sidebar,.top-bar,.section-header button{display:none!important}
  .main-content{margin:0!important;padding:0!important}
  .ops-logbook{border:none;box-shadow:none}
  .logbook-header{background:#1a365d!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .logbook-table th{background:#edf2f7!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .ops-template-print-page{background:#fff!important;padding:0}
  .ops-template-page{max-width:none;padding:0;background:#fff!important}
  .ops-logbook-template{border:1px solid #d5deea;box-shadow:none}
  .logbook-header-template,
  .logbook-template-footer,
  .template-meta-card,
  .logbook-template-table th,
  .logbook-template-row .row-num{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* Button variants */
.btn-success{background:#059669;color:#fff;border:none}
.btn-success:hover{background:#047857}
.btn-xs{padding:3px 8px;font-size:.68rem;border-radius:6px}
