
/* NEMBE E&P Intranet — LIGHT theme (v5). Brand red #E30420 + navy #212844.
   Light pages & white cards with dark text; vibrant dark gradient heroes/banners. */
:root{
  --red:#E30420; --red-2:#b40319; --red-3:#7d0212; --red-glow:rgba(227,4,32,.30);
  --navy:#212844; --navy-2:#16203a; --navy-3:#10142a;
  --gold:#c87f12; --gold-bg:#E8A23D; --teal:#0f8f76; --blue:#2f6fd0;
  --ink:#eef1f7; --ink-2:#e7ecf4;
  --glass:#ffffff; --glass-2:#f5f8fc; --glass-3:#eef3f9;
  --line:rgba(28,40,72,.13); --line-2:rgba(28,40,72,.07);
  --text:#1a2238; --muted:#566280; --muted-2:#8893a8;
  --r-sm:10px; --r:16px; --r-lg:22px; --r-xl:30px; --pill:999px;
  --shadow:0 18px 44px -24px rgba(20,30,60,.34); --shadow-soft:0 10px 28px -18px rgba(20,30,60,.22);
  --maxw:1200px; --nav-h:64px;
  --font:"Libre Franklin","Franklin Gothic Medium","ITC Franklin Gothic","Franklin Gothic",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--text);background:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(800px 520px at 8% -10%, rgba(227,4,32,.07), transparent 60%),radial-gradient(820px 560px at 100% 0%, rgba(33,40,68,.07), transparent 55%),linear-gradient(180deg,#f1f4fa 0%,#eef1f7 60%,#e9edf5 100%)}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;background-image:radial-gradient(rgba(28,40,72,.05) 1px,transparent 1px);background-size:46px 46px;-webkit-mask-image:linear-gradient(180deg,#000,transparent 75%);mask-image:linear-gradient(180deg,#000,transparent 75%)}
img{max-width:100%;display:block} a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0 0 .4em;line-height:1.13;letter-spacing:-.02em;font-weight:700;color:var(--text)}
h1{font-size:clamp(2rem,4.4vw,3.2rem)} h2{font-size:clamp(1.4rem,2.5vw,2rem)} h3{font-size:1.12rem}
p{margin:0 0 1rem;color:var(--muted)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px} .tight{max-width:920px}
.eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:.71rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--red);background:rgba(227,4,32,.08);border:1px solid rgba(227,4,32,.22);padding:5px 11px;border-radius:var(--pill)}
.eyebrow svg{width:14px;height:14px}
.lead{font-size:1.05rem;color:var(--muted);max-width:64ch} .muted{color:var(--muted)} .small{font-size:.82rem} .center{text-align:center} .mt0{margin-top:0}

/* nav (light glass) */
.nav-wrap{position:sticky;top:14px;z-index:60;padding:0 16px;margin-bottom:6px}
.nav{max-width:1280px;margin:0 auto;display:flex;align-items:center;gap:12px;height:var(--nav-h);padding:0 10px 0 14px;border-radius:var(--pill);background:rgba(255,255,255,.86);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.0rem;white-space:nowrap;color:var(--text)}
.brand .mark{width:30px;height:30px;flex:0 0 auto;object-fit:contain}
.brand small{display:block;font-size:.56rem;font-weight:600;letter-spacing:.16em;color:var(--muted-2);text-transform:uppercase;margin-top:-2px}
.nav-links{display:flex;align-items:center;gap:1px;margin-left:4px}
.nav-links a,.nav-drop>button{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:var(--muted);padding:8px 10px;border-radius:var(--pill);border:1px solid transparent;background:none;cursor:pointer;font-family:inherit;transition:.18s;white-space:nowrap}
.nav-links a:hover,.nav-drop>button:hover{color:var(--text);background:var(--glass-3)}
.nav-links a.active{color:var(--red);background:rgba(227,4,32,.10);border-color:rgba(227,4,32,.28)}
.nav-spacer{flex:1} .nav-tools{display:flex;align-items:center;gap:6px}
.icon-btn{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;border:1px solid var(--line);background:var(--glass);color:var(--muted);cursor:pointer;transition:.18s;position:relative}
.icon-btn:hover{color:var(--text);background:var(--glass-3);transform:translateY(-1px)} .icon-btn svg{width:18px;height:18px}
.icon-btn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--red);box-shadow:0 0 0 2px #fff}
.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:.82rem;color:#fff;cursor:pointer;background:linear-gradient(135deg,var(--red),var(--red-2));box-shadow:0 6px 14px -6px var(--red-glow)}
.nav-drop{position:relative}
.menu{position:absolute;top:calc(100% + 10px);right:0;min-width:230px;padding:8px;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(-6px);transition:.18s;z-index:80}
.nav-drop.open .menu{opacity:1;visibility:visible;transform:translateY(0)}
.menu a{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:10px;font-size:.85rem;color:var(--muted);font-weight:600}
.menu a svg{width:17px;height:17px;color:var(--muted-2)} .menu a:hover{background:var(--glass-3);color:var(--text)}
.menu .sep{height:1px;background:var(--line-2);margin:6px 4px}
.menu small{padding:6px 11px 2px;color:var(--muted-2);font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;display:block}
.hamburger{display:none}
.drawer{position:fixed;inset:0;z-index:90;background:rgba(20,28,50,.4);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:.2s}
.drawer.open{opacity:1;visibility:visible}
.drawer-panel{position:absolute;top:0;right:0;width:min(340px,87vw);height:100%;background:#fff;border-left:1px solid var(--line);padding:22px 18px;transform:translateX(100%);transition:.26s cubic-bezier(.4,.9,.3,1);overflow-y:auto}
.drawer.open .drawer-panel{transform:translateX(0)}
.drawer-panel a{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;font-weight:600;color:var(--muted);border:1px solid transparent;font-size:.92rem}
.drawer-panel a svg{width:19px;height:19px} .drawer-panel a:hover,.drawer-panel a.active{background:var(--glass-3);color:var(--text);border-color:var(--line)}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:inherit;font-weight:700;font-size:.9rem;cursor:pointer;border:0;padding:12px 22px;border-radius:var(--r-sm);transition:.2s;white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn-primary{color:#fff;background:linear-gradient(135deg,var(--red),var(--red-2));box-shadow:0 10px 24px -12px var(--red-glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -14px var(--red-glow)}
.btn-ghost{color:var(--text);background:var(--glass);border:1px solid var(--line)} .btn-ghost:hover{background:var(--glass-3);transform:translateY(-2px)}
.btn-light{background:var(--navy);color:#fff} .btn-light:hover{transform:translateY(-2px)}
.btn-navy{background:linear-gradient(135deg,#2c355c,var(--navy));color:#fff}
.btn-sm{padding:9px 15px;font-size:.8rem} .btn-block{width:100%}

/* cards */
.card{background:var(--glass);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;box-shadow:var(--shadow-soft);transition:.22s;position:relative;overflow:hidden}
.card.hover:hover{transform:translateY(-4px);border-color:rgba(227,4,32,.35);box-shadow:var(--shadow)}
.card-link::after{content:"\2192";position:absolute;right:18px;bottom:16px;color:var(--red);opacity:0;transform:translateX(-6px);transition:.22s;font-weight:800}
.card-link:hover::after{opacity:1;transform:translateX(0)}
.panel{background:var(--glass);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-soft)}
.grid{display:grid;gap:18px} .g-2{grid-template-columns:repeat(2,1fr)} .g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)} .g-5{grid-template-columns:repeat(5,1fr)} .g-auto{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
.row{display:flex;gap:14px;flex-wrap:wrap} .between{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
/* icons (smaller, beside headers) */
.ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:0 0 auto;background:rgba(227,4,32,.10);border:1px solid rgba(227,4,32,.22);color:var(--red)}
.ic svg{width:17px;height:17px}
.ic.navy{background:rgba(47,111,208,.10);border-color:rgba(47,111,208,.24);color:var(--blue)} .ic.gold{background:rgba(232,162,61,.12);border-color:rgba(232,162,61,.30);color:var(--gold)} .ic.teal{background:rgba(15,143,118,.10);border-color:rgba(15,143,118,.24);color:var(--teal)}
.ic.lg{width:40px;height:40px;border-radius:11px} .ic.lg svg{width:20px;height:20px}
.tag{display:inline-flex;align-items:center;gap:6px;font-size:.69rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:4px 10px;border-radius:var(--pill);background:var(--glass-3);border:1px solid var(--line);color:var(--muted)}
.tag.red{background:#fdecee;border-color:#f6c9ce;color:#b40319} .tag.green{background:#e6f6f1;border-color:#bfe6db;color:#0f6e56}
.tag.gold{background:#fbf1dc;border-color:#eed7a6;color:#8a5a12} .tag.navy{background:#e9eefb;border-color:#cdd9f3;color:#1d3a78}
.sec{padding:58px 0} .sec-sm{padding:36px 0} .sec-head{margin-bottom:26px;max-width:780px} .sec-head h2{margin-bottom:.3em}

/* banner (dark, vibrant) */
.banner{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:44px 38px;margin:8px 0 6px;background:linear-gradient(120deg,var(--navy) 0%,#1a2138 52%,#2a0610 100%);border:1px solid rgba(0,0,0,.2);box-shadow:var(--shadow);color:#fff}
.banner::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(560px 300px at 88% -20%, rgba(227,4,32,.45), transparent 60%)}
.banner>*{position:relative;z-index:1} .banner h1{margin-bottom:.25em;color:#fff} .banner .lead{color:#d7deea} .banner p{color:#d7deea}
.crumbs{font-size:.8rem;color:#aeb8cc;margin-bottom:14px} .crumbs a{color:#cdd6e6} .crumbs a:hover{color:#fff}

/* hero (dark, vibrant on light page) */
.hero{position:relative;border-radius:var(--r-xl);overflow:hidden;margin-top:8px;border:1px solid rgba(0,0,0,.2);box-shadow:var(--shadow);min-height:540px;display:flex;align-items:center;color:#fff}
.hero-bg{position:absolute;inset:0;z-index:0;background:linear-gradient(125deg,#2a0610 0%,#161b33 42%,#10142a 70%,#2a0610 100%);background-size:240% 240%;animation:heroPan 22s ease-in-out infinite}
@keyframes heroPan{0%{background-position:0% 40%}50%{background-position:100% 60%}100%{background-position:0% 40%}}
.hero-bg::before{content:"";position:absolute;inset:0;background:radial-gradient(620px 420px at 22% 18%, rgba(227,4,32,.34), transparent 60%),radial-gradient(680px 520px at 82% 86%, rgba(40,70,150,.40), transparent 62%)}
.hero-canvas{position:absolute;inset:0;z-index:1;opacity:.85}
.hero-grid{position:absolute;inset:0;z-index:0;opacity:.18;background:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:54px 54px;-webkit-mask-image:radial-gradient(circle at 50% 40%,#000,transparent 78%);mask-image:radial-gradient(circle at 50% 40%,#000,transparent 78%)}
.hero-inner{position:relative;z-index:3;width:100%;padding:54px 44px;text-align:center;display:flex;flex-direction:column;align-items:center;color:#fff}
.hero h1{font-size:clamp(2.2rem,5.2vw,3.9rem);font-weight:800;max-width:18ch;color:#fff}
.hero h1 .accent{background:linear-gradient(120deg,#ff5d6e,#ffa3ac);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lead{margin:0 auto 26px;text-align:center;font-size:1.1rem;color:#dbe3f0;max-width:60ch}
.hero-emblem{width:96px;height:96px;margin-bottom:18px;filter:drop-shadow(0 12px 26px var(--red-glow));animation:floaty 6s ease-in-out infinite}
.hero-emblem .spin{transform-origin:50% 50%;animation:spin 26s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}} @keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.greeting{font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-bg);font-weight:700;margin-bottom:14px}
.hero-clock{display:inline-flex;gap:16px;align-items:center;margin-top:8px;padding:10px 18px;border-radius:var(--pill);background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.14);font-variant-numeric:tabular-nums;color:#fff}
.hero-clock b{font-size:1.05rem} .hero-clock svg{width:18px;height:18px} .hero-clock .muted{color:#c2cbdb!important}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:8px}
/* hero ticker (inside dark hero) — label fixed, track scrolls behind */
.ticker{margin-top:14px;border:1px solid rgba(255,255,255,.16);border-radius:var(--pill);background:rgba(0,0,0,.30);overflow:hidden;display:flex;align-items:center;max-width:100%;position:relative}
.ticker .lbl{flex:0 0 auto;background:var(--red);color:#fff;font-weight:800;font-size:.7rem;letter-spacing:.1em;padding:10px 16px;text-transform:uppercase;position:relative;z-index:2}
.tk-view{flex:1;overflow:hidden;position:relative;z-index:1}
.ticker-track{display:flex;gap:40px;white-space:nowrap;padding:10px 18px;animation:ticker 34s linear infinite;font-size:.83rem;color:#c8d2e2}
.ticker-track b{color:#fff} .ticker-track .up{color:#67e0b6} .ticker-track .dn{color:#ff9098}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.kpi{display:flex;flex-direction:column;gap:6px}
.kpi .num{font-size:2rem;font-weight:800;letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums;color:var(--navy)}
.kpi .lab{font-size:.77rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em} .kpi .sub{font-size:.78rem}
.stat-strip{display:grid;grid-template-columns:repeat(5,1fr);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--glass);box-shadow:var(--shadow-soft)}
.stat-strip>div{padding:20px;border-right:1px solid var(--line-2)} .stat-strip>div:last-child{border-right:0}
.ql{display:flex;flex-direction:column;gap:10px;align-items:flex-start} .ql .ic{margin-bottom:2px} .ql h3{font-size:1rem;margin:0} .ql p{font-size:.84rem;margin:0}

/* forms */
.field{margin-bottom:15px} .field label{display:block;font-size:.8rem;font-weight:600;color:var(--muted);margin-bottom:7px}
.input,.select,textarea.input{width:100%;padding:11px 14px;border-radius:var(--r-sm);background:#fff;border:1px solid var(--line);color:var(--text);font-family:inherit;font-size:.9rem;transition:.18s}
.input:focus,.select:focus,textarea.input:focus{outline:0;border-color:var(--red);box-shadow:0 0 0 3px rgba(227,4,32,.14)}
textarea.input{min-height:110px;resize:vertical} .form-note{font-size:.78rem;color:var(--muted-2)}
.ok-msg{display:none;align-items:center;gap:10px;padding:13px 16px;border-radius:var(--r-sm);background:#e6f6f1;border:1px solid #bfe6db;color:#0f6e56;font-size:.86rem;font-weight:600;margin-top:6px}
.ok-msg svg{width:18px;height:18px} .ok-msg.show{display:flex;animation:pop .3s ease}
@keyframes pop{from{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}

.table{width:100%;border-collapse:collapse;font-size:.86rem} .table-wrap{overflow-x:auto;border-radius:var(--r)}
.table th{text-align:left;font-size:.69rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2);font-weight:700;padding:11px 13px;border-bottom:1px solid var(--line);white-space:nowrap}
.table td{padding:12px 13px;border-bottom:1px solid var(--line-2);color:var(--text);vertical-align:top}
.table tr:hover td{background:var(--glass-2)} .table .file{display:flex;align-items:center;gap:10px;font-weight:600} .table .file svg{width:18px;height:18px;color:var(--red);flex:0 0 auto}
.search{position:relative;max-width:420px} .search input{padding-left:42px}
.search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--muted-2)}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:.8rem;font-weight:600;color:var(--muted);padding:8px 14px;border-radius:var(--pill);background:var(--glass);border:1px solid var(--line);cursor:pointer;transition:.16s;display:inline-flex;align-items:center;gap:7px;font-family:inherit}
.chip svg{width:15px;height:15px} .chip:hover{color:var(--text);background:var(--glass-3)} .chip.active{background:rgba(227,4,32,.10);border-color:rgba(227,4,32,.3);color:var(--red)}
.person{display:flex;gap:14px;align-items:center}
.pf{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:#fff;flex:0 0 auto;font-size:.92rem}
.person h4{margin:0;font-size:.95rem;color:var(--text)} .person .role{font-size:.8rem;color:var(--muted)} .person .meta{font-size:.76rem;color:var(--muted-2);margin-top:3px} .person .meta svg{width:13px;height:13px;vertical-align:-2px}
.timeline{position:relative;padding-left:26px} .timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:linear-gradient(var(--red),rgba(227,4,32,.1))}
.tl-item{position:relative;margin-bottom:22px} .tl-item::before{content:"";position:absolute;left:-26px;top:5px;width:13px;height:13px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px rgba(227,4,32,.14)}
.tl-item .yr{font-weight:800;color:var(--red);font-size:.9rem} .tl-item b{color:var(--text)}
.org{display:flex;flex-direction:column;align-items:center}
.org-node{background:var(--glass);border:1px solid var(--line);border-radius:14px;padding:11px 16px;text-align:center;min-width:158px;box-shadow:var(--shadow-soft)}
.org-node b{display:block;color:var(--text)} .org-node span{font-size:.77rem;color:var(--muted)}
.org-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center} .org-conn{width:2px;height:22px;background:var(--line)}
.bar-track{height:9px;border-radius:var(--pill);background:rgba(28,40,72,.10);overflow:hidden}
.bar-fill{height:100%;border-radius:var(--pill);width:0;transition:width 1.4s cubic-bezier(.2,.8,.2,1);background:linear-gradient(90deg,var(--red),#ff6a73)}
.bar-fill.navy{background:linear-gradient(90deg,#2f6fd0,#6fa0e8)} .bar-fill.gold{background:linear-gradient(90deg,#d9962b,#f0c069)} .bar-fill.teal{background:linear-gradient(90deg,#0f8f76,#43c2a7)}
.ring{--p:0;width:116px;height:116px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--red) calc(var(--p)*1%), rgba(28,40,72,.10) 0)}
.ring .inner{width:86px;height:86px;border-radius:50%;background:#fff;display:grid;place-items:center;text-align:center;box-shadow:inset 0 0 0 1px var(--line-2)}
.ring .inner b{font-size:1.4rem;display:block;color:var(--navy)} .ring .inner span{font-size:.7rem;color:var(--muted)}
.chart{width:100%;height:auto;overflow:visible} .chart .grid-l{stroke:rgba(28,40,72,.10)}
.chart .area{opacity:.16} .chart .line{fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round} .chart .dash{stroke-dasharray:5 5;opacity:.7}
.line.draw{stroke-dasharray:2600;stroke-dashoffset:2600;animation:draw 2.4s ease .25s forwards} @keyframes draw{to{stroke-dashoffset:0}}
.legend{display:flex;gap:18px;flex-wrap:wrap;font-size:.8rem;color:var(--muted)} .legend i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:6px;vertical-align:-1px}
.sdot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:7px} .sdot.on{background:#1fbf90} .sdot.warn{background:#d9962b} .sdot.off{background:#ef4646}
.acc{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--glass)} .acc+.acc{margin-top:10px}
.acc summary{padding:15px 18px;cursor:pointer;font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;color:var(--text)}
.acc summary::-webkit-details-marker{display:none} .acc summary::after{content:"+";color:var(--red);font-size:1.3rem;font-weight:700;transition:.2s}
.acc[open] summary::after{transform:rotate(45deg)} .acc .acc-body{padding:0 18px 16px;color:var(--muted);font-size:.9rem}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gallery figure{margin:0;border-radius:var(--r);overflow:hidden;cursor:pointer;position:relative;aspect-ratio:4/3;border:1px solid var(--line);transition:.22s;box-shadow:var(--shadow-soft)}
.gallery figure:hover{transform:translateY(-3px);box-shadow:var(--shadow)} .gallery figure img{width:100%;height:100%;object-fit:cover}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:10px 12px;font-size:.78rem;font-weight:600;color:#fff;background:linear-gradient(transparent,rgba(10,16,30,.82))}
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(15,22,40,.8);backdrop-filter:blur(6px);display:none;place-items:center;padding:30px}
.lightbox.open{display:grid;animation:pop .25s ease} .lightbox .lb-inner{max-width:880px;width:100%}
.lightbox svg,.lightbox img{width:100%;border-radius:var(--r-lg);border:1px solid var(--line)} .lightbox .cap{text-align:center;margin-top:14px;color:#dfe5f0}
.lb-close{position:absolute;top:22px;right:26px;font-size:1.7rem;cursor:pointer;color:#fff}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal .dow{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-2);text-align:center;padding:6px 0;font-weight:700}
.cal .day{aspect-ratio:1;border-radius:10px;border:1px solid var(--line-2);padding:7px;font-size:.8rem;background:var(--glass);position:relative;color:var(--text)}
.cal .day.muted{opacity:.4} .cal .day.today{border-color:var(--red);background:rgba(227,4,32,.08)}
.cal .day .ev{position:absolute;left:6px;right:6px;bottom:6px;height:5px;border-radius:3px;background:var(--red)} .cal .day .ev.navy{background:#2f6fd0} .cal .day .ev.gold{background:#d9962b}
.news-item{display:flex;flex-direction:column;height:100%} .news-cover{height:148px;border-radius:var(--r);margin-bottom:14px;position:relative;overflow:hidden} .news-cover .tag{position:absolute;top:10px;left:10px}
.news-item h3{font-size:1.04rem} .news-meta{font-size:.76rem;color:var(--muted-2);margin-top:auto;padding-top:10px}
.reveal{opacity:0;transform:translateY(20px);transition:.7s cubic-bezier(.2,.8,.2,1)} .reveal.in{opacity:1;transform:none}
.divider{height:1px;background:var(--line);margin:30px 0}
.list-check{list-style:none;padding:0;margin:0} .list-check li{position:relative;padding:7px 0 7px 28px;color:var(--muted);font-size:.92rem}
.list-check li::before{content:"";position:absolute;left:0;top:11px;width:16px;height:16px;border-radius:50%;background:rgba(227,4,32,.1);border:1px solid var(--red)}
.list-check li::after{content:"";position:absolute;left:5px;top:14px;width:5px;height:8px;border:solid var(--red);border-width:0 2px 2px 0;transform:rotate(45deg)}
.kv{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:.88rem} .kv:last-child{border-bottom:0} .kv span{color:var(--muted)} .kv b{font-weight:700;color:var(--text)}
/* footer (light) */
.footer{margin-top:56px;border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,#e9edf5)}
.footer .container{padding-top:42px;padding-bottom:28px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
.footer h5{font-size:.73rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted-2);margin:0 0 14px}
.footer a{display:block;color:var(--muted);font-size:.86rem;padding:5px 0;transition:.16s} .footer a:hover{color:var(--red);transform:translateX(3px)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-top:32px;padding-top:20px;border-top:1px solid var(--line-2);font-size:.8rem;color:var(--muted-2)}
.foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.ribbon{display:flex;justify-content:center;align-items:center;gap:34px;flex-wrap:wrap;opacity:.85;padding:10px 0}
.ribbon span{font-weight:700;font-size:.9rem;display:flex;align-items:center;gap:8px;color:var(--muted)} .ribbon svg{width:18px;height:18px;color:var(--red)}
/* pillars / mindmap */
.pillar{cursor:pointer} .pillar .ic{margin-bottom:12px} .pillar .score{font-size:1.8rem;font-weight:800;line-height:1}
.mm{display:flex;flex-direction:column;align-items:center;gap:0}
.mm-core{background:linear-gradient(135deg,var(--red),var(--red-2));color:#fff;border-radius:18px;padding:16px 26px;text-align:center;box-shadow:0 12px 26px -14px var(--red-glow);font-weight:800}
.mm-core span{display:block;font-size:.72rem;font-weight:600;opacity:.9;text-transform:uppercase;letter-spacing:.12em}
.mm-branches{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:26px;width:100%}
.mm-node{background:var(--glass);border:1px solid var(--line);border-radius:16px;padding:18px;cursor:pointer;transition:.2s;text-align:center;position:relative;box-shadow:var(--shadow-soft)}
.mm-node:hover{transform:translateY(-4px);border-color:rgba(227,4,32,.3);box-shadow:var(--shadow)} .mm-node .ic{margin:0 auto 10px} .mm-node h4{margin:0;font-size:.96rem;color:var(--text)} .mm-node .pct{font-size:1.5rem;font-weight:800;margin-top:6px}
.mm-node.active{border-color:var(--red);background:rgba(227,4,32,.06)}
.mm-detail{margin-top:18px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--glass);padding:24px;display:none;animation:pop .3s ease;box-shadow:var(--shadow-soft)} .mm-detail.show{display:block} .mm-detail h3{color:var(--text)}
.heat{display:grid;grid-template-columns:auto repeat(5,1fr);gap:5px;font-size:.74rem}
.heat .hc{aspect-ratio:1.6;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff}
.heat .axis{display:flex;align-items:center;justify-content:center;color:var(--muted-2);font-weight:700;font-size:.7rem}
.heat .l{background:#1fbf90} .heat .m{background:#d9962b} .heat .h{background:#ef7a3d} .heat .c{background:#E30420}
.gantt{font-size:.8rem} .gantt-row{display:grid;grid-template-columns:200px 1fr;gap:10px;align-items:center;padding:6px 0;border-bottom:1px solid var(--line-2)}
.gantt-row .lbl{color:var(--muted);font-weight:600} .gantt-bars{display:grid;grid-template-columns:repeat(12,1fr);gap:3px;height:18px}
.gantt-cell{border-radius:4px;background:rgba(28,40,72,.07)} .gantt-cell.on{background:linear-gradient(90deg,var(--red),#ff6a73)} .gantt-cell.gov{background:linear-gradient(90deg,#2f6fd0,#6fa0e8)} .gantt-cell.cmp{background:linear-gradient(90deg,#0f8f76,#43c2a7)}
.gantt-months{display:grid;grid-template-columns:200px 1fr} .gantt-months .mm12{display:grid;grid-template-columns:repeat(12,1fr);gap:3px;font-size:.62rem;color:var(--muted-2);text-align:center}
.metric{display:flex;flex-direction:column;gap:8px;padding:18px;border-radius:var(--r);border:1px solid var(--line);background:var(--glass);box-shadow:var(--shadow-soft)}
.metric .top{display:flex;justify-content:space-between;align-items:center} .metric .v{font-size:1.7rem;font-weight:800;color:var(--navy)} .metric .t{font-size:.82rem;color:var(--muted)} .metric .tl{width:13px;height:13px;border-radius:50%}
.tl-g{background:#1fbf90} .tl-a{background:#d9962b} .tl-r{background:#ef4646}
.job{display:flex;gap:16px;align-items:flex-start;padding:18px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--glass);transition:.2s;box-shadow:var(--shadow-soft)}
.job:hover{transform:translateY(-3px);border-color:rgba(227,4,32,.3);box-shadow:var(--shadow)} .job h3{margin:0 0 4px;font-size:1.05rem;color:var(--text)} .job .meta{display:flex;gap:14px;flex-wrap:wrap;font-size:.78rem;color:var(--muted-2);margin-top:8px} .job .meta span{display:inline-flex;align-items:center;gap:5px} .job .meta svg{width:14px;height:14px}
.steps{display:flex;gap:8px;flex-wrap:wrap;counter-reset:s}
.step{flex:1;min-width:120px;border:1px solid var(--line);border-radius:var(--r);padding:14px;background:var(--glass);position:relative;box-shadow:var(--shadow-soft)} .step b{color:var(--text)}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:-10px;left:14px;width:24px;height:24px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;font-size:.75rem;font-weight:800}
/* login */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;background:#fff}
.login-art{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:46px;background:linear-gradient(140deg,#2a0610,#161b33 55%,#10142a);color:#fff}
.login-art .bg{position:absolute;inset:0;z-index:0} .login-art>*{position:relative;z-index:2}
.login-tag{font-size:clamp(2rem,3.6vw,3.1rem);font-weight:800;line-height:1.05;max-width:15ch} .login-tag .accent{color:#ff7d88}
.login-art .lead{color:#d7deea} .login-art .list-check li{color:#cdd6e6} .login-art .muted{color:#aeb8cc!important}
.login-form{display:flex;flex-direction:column;justify-content:center;padding:46px;max-width:520px;margin:0 auto;width:100%} .login-card{width:100%}
.sso{display:flex;gap:10px} .sso .btn{flex:1}
@media(max-width:880px){.login-wrap{grid-template-columns:1fr} .login-art{min-height:230px}}
.post-cover{height:200px;border-radius:var(--r-lg);position:relative;overflow:hidden}
.feature-post{display:grid;grid-template-columns:1.2fr 1fr;gap:0;overflow:hidden} @media(max-width:760px){.feature-post{grid-template-columns:1fr}}
.scorecard td .mini{height:6px;border-radius:3px;background:rgba(28,40,72,.10);overflow:hidden;min-width:80px} .scorecard td .mini i{display:block;height:100%;background:linear-gradient(90deg,var(--red),#ff6a73)}
.tabbar{display:flex;gap:8px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin-bottom:22px} .tabbar .chip{border-radius:var(--r-sm) var(--r-sm) 0 0;border-bottom:0}
/* news ticker (light bar) */
.newsbar{max-width:1280px;margin:0 auto 8px;border:1px solid var(--line);border-radius:var(--pill);background:rgba(255,255,255,.92);box-shadow:var(--shadow-soft);overflow:hidden;display:flex;align-items:center}
.newsbar .nb-cat{flex:0 0 auto;background:linear-gradient(135deg,var(--red),var(--red-2));color:#fff;font-weight:800;font-size:.66rem;letter-spacing:.05em;padding:9px 14px;text-transform:uppercase;white-space:nowrap;position:relative;z-index:3}
.newsbar .nb-view{flex:1;overflow:hidden;position:relative;z-index:1}
.newsbar .nb-track{display:flex;gap:28px;white-space:nowrap;padding:9px 18px;animation:ticker 70s linear infinite;font-size:.8rem;color:var(--muted);will-change:transform}
.newsbar:hover .nb-track{animation-play-state:paused}
.newsbar .nb-track a{color:var(--text);cursor:pointer} .newsbar .nb-track a:hover{color:var(--red)} .newsbar .nb-track .dot{color:var(--red)}
@media(max-width:860px){.newsbar{margin-left:16px;margin-right:16px}}
.course{display:flex;flex-direction:column;height:100%} .course .top{height:84px;border-radius:var(--r);margin-bottom:12px;position:relative;display:flex;align-items:flex-end;padding:10px}
.badgec{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;color:#6a4a08;background:#fbf1dc;border:1px solid #eed7a6;padding:4px 10px;border-radius:var(--pill)} .badgec svg{width:14px;height:14px}
.pricetile{display:flex;flex-direction:column;gap:4px;padding:16px;border:1px solid var(--line);border-radius:var(--r);background:var(--glass);box-shadow:var(--shadow-soft)} .pricetile .v{font-size:1.5rem;font-weight:800;font-variant-numeric:tabular-nums;color:var(--navy)}
.newsfeed a{display:block;padding:12px 4px;border-bottom:1px solid var(--line-2);color:var(--text);font-weight:600;font-size:.92rem;transition:.16s;cursor:pointer} .newsfeed a:hover{color:var(--red);padding-left:8px} .newsfeed a span{display:block;color:var(--muted-2);font-size:.74rem;font-weight:400;margin-top:3px}
.path-step{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line-2)} .path-step .n{width:30px;height:30px;border-radius:50%;background:rgba(227,4,32,.1);border:1px solid var(--red);color:var(--red);display:grid;place-items:center;font-weight:800;flex:0 0 auto} .path-step b{color:var(--text)}
/* JD / news reader modal */
#jdmodal .jd-modal,#newsreader .nr-modal{max-width:900px;width:100%;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:0;max-height:88vh;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
#jdmodal .jd-modal{padding:30px 32px;overflow:auto}
.jd-body h3{margin:0 0 4px} .jd-body h4{margin:16px 0 6px;font-size:.95rem;color:var(--navy)} .jd-body .role-sub{color:var(--muted);font-size:.9rem;margin-bottom:10px}
.jd-body ul{margin:6px 0 12px;padding-left:18px} .jd-body li{color:var(--muted);font-size:.9rem;margin:4px 0}
.nr-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line)} .nr-head b{flex:1;font-size:.95rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nr-frame{width:100%;height:64vh;border:0;background:#fff} .nr-fallback{padding:14px 18px;font-size:.82rem;color:var(--muted-2);border-top:1px solid var(--line)}
/* photos */
.photo{border-radius:var(--r-lg);border:1px solid var(--line);overflow:hidden;position:relative;box-shadow:var(--shadow-soft)}
.photo img{width:100%;height:100%;object-fit:cover;display:block;transition:.5s} .photo:hover img{transform:scale(1.05)}
.photo .cap{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;font-weight:600;font-size:.86rem;color:#fff;background:linear-gradient(transparent,rgba(10,16,30,.85))}
.photo-tall{aspect-ratio:3/4} .photo-wide{aspect-ratio:16/9} .photo-sq{aspect-ratio:1}
.hero-photo{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.5}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(33,40,68,.82),rgba(10,14,28,.62) 50%,rgba(42,6,16,.78))}
.banner-photo{position:absolute;right:0;top:0;bottom:0;width:44%;z-index:0;background-size:cover;background-position:center;opacity:.5;-webkit-mask-image:linear-gradient(90deg,transparent,#000 60%);mask-image:linear-gradient(90deg,transparent,#000 60%)}
.vchain{display:flex;gap:8px;flex-wrap:wrap}
.vc-step{flex:1;min-width:150px;border:1px solid var(--line);border-radius:var(--r);padding:16px;background:var(--glass);cursor:pointer;transition:.2s;position:relative;box-shadow:var(--shadow-soft)}
.vc-step:hover{transform:translateY(-3px);border-color:rgba(227,4,32,.35);box-shadow:var(--shadow)} .vc-step.active{border-color:var(--red);background:rgba(227,4,32,.06)}
.vc-step .n{font-size:.7rem;font-weight:800;color:var(--red);letter-spacing:.1em} .vc-step h4{margin:6px 0 2px;font-size:.95rem;color:var(--text)} .vc-step .small{margin:0;font-size:.76rem}
.comply{display:flex;flex-direction:column;height:460px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--glass);overflow:hidden;box-shadow:var(--shadow-soft)}
.comply-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line);background:linear-gradient(135deg,rgba(227,4,32,.06),transparent)} .comply-head b{color:var(--text)}
.comply-head .ai{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,var(--red),var(--red-2));color:#fff}
.chat-log{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px}
.chat-msg{max-width:86%;padding:12px 14px;border-radius:14px;font-size:.9rem;line-height:1.5}
.chat-msg.user{align-self:flex-end;background:linear-gradient(135deg,var(--red),var(--red-2));color:#fff;border-bottom-right-radius:4px}
.chat-msg.bot{align-self:flex-start;background:var(--glass-3);border:1px solid var(--line);border-bottom-left-radius:4px;color:var(--text)}
.chat-msg.bot b{color:var(--navy)} .chat-msg.bot .cite{display:inline-block;font-size:.72rem;color:#b40319;background:#fdecee;border:1px solid #f6c9ce;padding:2px 8px;border-radius:var(--pill);margin:3px 4px 0 0}
.chat-in{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)} .chat-in input{flex:1}
.qbtns{display:flex;gap:7px;flex-wrap:wrap;padding:0 12px 12px}
.qbtns button{font-size:.76rem;padding:6px 11px;border-radius:var(--pill);border:1px solid var(--line);background:var(--glass);color:var(--muted);cursor:pointer;font-family:inherit} .qbtns button:hover{color:var(--text);background:var(--glass-3)}
.corpus{display:flex;gap:8px;flex-wrap:wrap} .corpus .doc{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;color:var(--muted);border:1px solid var(--line);background:var(--glass);padding:7px 11px;border-radius:var(--pill)} .corpus .doc svg{width:14px;height:14px;color:var(--red)}
.embed-frame{width:100%;height:760px;border:1px solid var(--line);border-radius:var(--r-lg);background:#fff}
.rhythm td.tn{color:#b40319;font-weight:700;white-space:nowrap} .rhythm td.tp{color:#0f6e56;font-weight:700;white-space:nowrap}
code{background:var(--glass-3);border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-size:.85em}
@media(max-width:1080px){.g-4,.g-5{grid-template-columns:repeat(2,1fr)} .stat-strip{grid-template-columns:repeat(3,1fr)} .stat-strip>div:nth-child(3){border-right:0} .gallery{grid-template-columns:repeat(3,1fr)} .foot-grid{grid-template-columns:1fr 1fr} .mm-branches{grid-template-columns:repeat(3,1fr)}}
@media(max-width:860px){.nav-links,.nav-tools .desktop-only{display:none} .hamburger{display:grid} .g-3,.g-2{grid-template-columns:1fr} .gantt-row{grid-template-columns:120px 1fr}}
@media(max-width:680px){.g-4,.g-5{grid-template-columns:1fr 1fr} .stat-strip{grid-template-columns:1fr 1fr} .stat-strip>div{border-right:0;border-bottom:1px solid var(--line-2)} .gallery{grid-template-columns:repeat(2,1fr)} .foot-grid{grid-template-columns:1fr} .hero-inner,.banner{padding:30px 20px} .sec{padding:40px 0} .mm-branches{grid-template-columns:1fr 1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ===== v6: tighter spacing, search, SPIRIT ===== */
.sec{padding:44px 0} .sec-sm{padding:24px 0} .sec-head{margin-bottom:22px}
.srch-box{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line)}
.srch-box input{flex:1;border:0;font-size:1.05rem;background:none;color:var(--text);outline:none;font-family:inherit}
.srch-results{max-height:58vh;overflow:auto;padding:8px}
.srch-results a{display:block;padding:11px 14px;border-radius:10px;color:var(--text)}
.srch-results a:hover{background:var(--glass-3)} .srch-results a b{display:block;font-size:.95rem} .srch-results a span{font-size:.8rem;color:var(--muted)}
.srch-empty{padding:22px;color:var(--muted-2);text-align:center}
kbd{background:var(--glass-3);border:1px solid var(--line);border-radius:6px;padding:1px 7px;font-size:.74rem;color:var(--muted)}
.spirit{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.spirit .s{text-align:center;padding:18px 12px;border:1px solid var(--line);border-radius:var(--r);background:var(--glass);box-shadow:var(--shadow-soft);transition:.2s}
.spirit .s:hover{transform:translateY(-3px);border-color:rgba(227,4,32,.3)} .spirit .s .l{font-size:1.9rem;font-weight:800;color:var(--red);line-height:1}
.spirit .s b{display:block;margin-top:6px;font-size:.92rem;color:var(--text)} .spirit .s p{font-size:.74rem;margin:4px 0 0;color:var(--muted)}
@media(max-width:860px){.spirit{grid-template-columns:repeat(3,1fr)}}

/* ===== v7: 3D cube logo, course player, socials, video ===== */
.cube-stage{width:132px;height:132px;margin:0 auto 16px;perspective:760px}
.cube-globe{position:relative;width:132px;height:132px;border-radius:50%;display:grid;place-items:center;animation:floaty 6s ease-in-out infinite;
 background:radial-gradient(circle at 34% 28%, rgba(255,255,255,.55), rgba(255,255,255,.10) 46%, rgba(33,40,68,.12) 72%, transparent 76%);
 box-shadow:0 20px 44px -18px rgba(0,0,0,.5), inset 0 0 34px rgba(255,255,255,.30)}
.cube-globe::after{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid rgba(255,255,255,.45);box-shadow:inset -10px -12px 26px rgba(33,40,68,.22), inset 10px 10px 22px rgba(255,255,255,.45)}
.cube{position:relative;width:76px;height:76px;transform-style:preserve-3d;animation:spin3d 9s linear infinite}
.cube .cf{position:absolute;width:76px;height:76px;display:grid;place-items:center;background:rgba(255,255,255,.62);border:1px solid rgba(227,4,32,.22);border-radius:9px}
.cube .cf img{width:54px;height:54px;object-fit:contain}
.cf.f1{transform:translateZ(38px)}.cf.f2{transform:rotateY(180deg) translateZ(38px)}.cf.f3{transform:rotateY(90deg) translateZ(38px)}.cf.f4{transform:rotateY(-90deg) translateZ(38px)}.cf.f5{transform:rotateX(90deg) translateZ(38px)}.cf.f6{transform:rotateX(-90deg) translateZ(38px)}
@keyframes spin3d{from{transform:rotateY(0deg)}to{transform:rotateY(360deg)}}
.vid{width:100%;border-radius:var(--r-lg);border:1px solid var(--line);display:block;background:#000;box-shadow:var(--shadow-soft)}
.socials{display:flex;gap:10px;margin-top:12px}
.socials a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line);background:var(--glass);color:var(--muted);transition:.18s}
.socials a:hover{color:#fff;background:linear-gradient(135deg,var(--red),var(--red-2));border-color:transparent;transform:translateY(-2px)}
.socials a svg{width:18px;height:18px}
.social-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.social-row a{display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border-radius:var(--pill);border:1px solid var(--line);background:var(--glass);font-weight:600;color:var(--text);transition:.18s;box-shadow:var(--shadow-soft)}
.social-row a:hover{transform:translateY(-2px);border-color:rgba(227,4,32,.4)} .social-row a svg{width:20px;height:20px;color:var(--red)}
/* course player */
.cbar{margin-bottom:18px} .cbar-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-weight:600}
.csteps{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.cstep{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:var(--glass);color:var(--muted);font-weight:800;cursor:pointer;font-family:inherit;transition:.16s}
.cstep.cur{border-color:var(--red);color:var(--red);background:rgba(227,4,32,.08)} .cstep.done{background:linear-gradient(135deg,var(--teal),#43c2a7);color:#fff;border-color:transparent}
.course-content{color:var(--muted);font-size:.95rem;line-height:1.7} .course-content ul{padding-left:18px} .course-content li{margin:5px 0} .course-content b{color:var(--text)}
.quiz{border:1px solid var(--line-2);border-radius:var(--r);padding:14px 16px;margin:12px 0;transition:.18s} .quiz.ok{border-color:#bfe6db;background:#e9f7f2} .quiz.no{border-color:#f6c9ce;background:#fdeef0}
.quiz .qq{font-weight:600;color:var(--text);margin:0 0 8px} .opt{display:block;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:.9rem} .opt:hover{background:var(--glass-3)} .opt input{margin-right:8px}

/* ===== v8: opaque solid cube + realistic 3D rotating glass globe ===== */
.cube-stage{width:164px;height:164px;perspective:820px;margin:0 auto 16px}
.cube-globe{width:164px;height:164px;border-radius:50%;position:relative;display:grid;place-items:center;animation:floatspin 7s ease-in-out infinite;
 background:radial-gradient(120px 120px at 32% 26%, rgba(255,255,255,.95), rgba(255,255,255,.25) 22%, rgba(255,255,255,0) 42%),
   radial-gradient(circle at 50% 52%, rgba(220,232,248,.06), rgba(120,140,180,.16) 58%, rgba(33,40,68,.30) 80%, rgba(33,40,68,.46) 100%);
 box-shadow:0 28px 54px -16px rgba(8,15,35,.62), inset -16px -18px 42px rgba(18,28,58,.5), inset 16px 18px 38px rgba(255,255,255,.6)}
.cube-globe::before{content:"";position:absolute;top:9%;left:13%;width:44%;height:34%;border-radius:50%;z-index:4;pointer-events:none;
 background:radial-gradient(circle at 42% 42%, rgba(255,255,255,.92), rgba(255,255,255,0) 70%);filter:blur(2px)}
.cube-globe::after{content:"";position:absolute;inset:0;border-radius:50%;z-index:4;pointer-events:none;
 border:1px solid rgba(255,255,255,.4);box-shadow:inset 0 -10px 26px rgba(20,30,60,.4), inset 0 8px 22px rgba(255,255,255,.4)}
.cube{width:86px;height:86px;transform-style:preserve-3d;animation:spin3d 8s linear infinite;z-index:2}
.cube .cf{position:absolute;width:86px;height:86px;display:grid;place-items:center;border-radius:6px;overflow:hidden;
 background:linear-gradient(152deg,#ffffff 0%,#eef2f8 60%,#e2e8f2 100%);border:1px solid rgba(227,4,32,.16);
 box-shadow:inset 0 0 0 1px rgba(255,255,255,.65), inset 0 -8px 16px rgba(33,40,68,.08)}
.cube .cf img{width:62px;height:62px;object-fit:contain}
.cf.f1{transform:translateZ(43px)} .cf.f2{transform:rotateY(180deg) translateZ(43px)}
.cf.f3{transform:rotateY(90deg) translateZ(43px);filter:brightness(.88)} .cf.f4{transform:rotateY(-90deg) translateZ(43px);filter:brightness(.88)}
.cf.f5{transform:rotateX(90deg) translateZ(43px);filter:brightness(1.06)} .cf.f6{transform:rotateX(-90deg) translateZ(43px);filter:brightness(.78)}
@keyframes spin3d{from{transform:rotateX(-16deg) rotateY(0deg)}to{transform:rotateX(-16deg) rotateY(360deg)}}
@keyframes floatspin{0%{transform:translateY(0) rotate(0deg) scale(1)}25%{transform:translateY(-13px) rotate(2.2deg) scale(1.015)}50%{transform:translateY(0) rotate(0deg) scale(1)}75%{transform:translateY(13px) rotate(-2.2deg) scale(.99)}100%{transform:translateY(0) rotate(0deg) scale(1)}}

/* ===== v8b: org detail + badge ===== */
.org-row.org-wrap{flex-wrap:wrap;gap:10px}
.orglist{list-style:none;padding:0;margin:0}
.orglist li{font-size:.82rem;color:var(--muted);padding:5px 0;border-bottom:1px dashed var(--line-2)}
.orglist li:last-child{border-bottom:0}
.badgec{display:inline-block;padding:8px 16px;border-radius:var(--pill);background:linear-gradient(135deg,var(--navy),#33406b);color:#fff;font-weight:700;letter-spacing:.02em}
.bcp-flow{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;counter-reset:bcp}
.bcp-flow .step2{position:relative;padding:16px 16px 16px 44px;border:1px solid var(--line);border-radius:var(--r);background:var(--glass);box-shadow:var(--shadow-soft)}
.bcp-flow .step2::before{counter-increment:bcp;content:counter(bcp);position:absolute;left:12px;top:14px;width:24px;height:24px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.8rem}

/* ===== v9: wellness assistant, profile modal, Nembe.ai, reporting ===== */
.well-fab{position:fixed;right:20px;bottom:20px;z-index:1200;width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;
 background:linear-gradient(135deg,var(--teal),#1f9e86);color:#fff;box-shadow:0 12px 30px -8px rgba(20,30,60,.5);display:grid;place-items:center;transition:.2s}
.well-fab:hover{transform:translateY(-3px) scale(1.04)} .well-fab svg{width:26px;height:26px}
.well-fab .dot{position:absolute;top:-3px;right:-3px;width:16px;height:16px;border-radius:50%;background:var(--red);color:#fff;font-size:.6rem;display:grid;place-items:center;font-weight:800;border:2px solid #fff}
.well-panel{position:fixed;right:20px;bottom:86px;z-index:1200;width:330px;max-width:calc(100vw - 40px);background:var(--glass);border:1px solid var(--line);border-radius:18px;box-shadow:0 26px 60px -18px rgba(8,15,35,.5);padding:18px;display:none;animation:wpop .25s ease}
.well-panel.open{display:block} @keyframes wpop{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.well-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px} .well-head b{font-size:1rem} .well-x{border:none;background:none;cursor:pointer;color:var(--muted);font-size:1.2rem}
.well-ring{display:block;margin:6px auto 4px} .well-ring .bg{fill:none;stroke:var(--line-2);stroke-width:10} .well-ring .fg{fill:none;stroke:var(--teal);stroke-width:10;stroke-linecap:round;transform:rotate(-90deg);transform-origin:60px 60px;transition:stroke-dashoffset .5s}
.well-ring.move .fg{stroke:var(--red)} .well-center{font-weight:800;font-size:1.5rem} .well-sub{text-align:center;color:var(--muted);font-size:.84rem;margin:2px 0 10px}
.well-cta{display:flex;gap:8px} .well-stat{display:flex;justify-content:space-around;margin-top:12px;border-top:1px solid var(--line-2);padding-top:10px}
.well-stat div{text-align:center} .well-stat b{display:block;font-size:1.1rem;color:var(--teal)} .well-stat span{font-size:.72rem;color:var(--muted)}
.well-tip{background:var(--glass-3);border-radius:10px;padding:10px 12px;font-size:.82rem;color:var(--text);margin-top:10px}
/* profile modal */
.prof-modal{position:fixed;inset:0;z-index:1300;background:rgba(10,15,30,.6);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:20px}
.prof-modal.open{display:flex} .prof-card{background:var(--glass);border-radius:20px;max-width:660px;width:100%;overflow:hidden;box-shadow:0 30px 70px -20px rgba(0,0,0,.5);animation:wpop .25s ease;display:grid;grid-template-columns:230px 1fr}
.prof-card .pp{background:linear-gradient(160deg,#27305a,#0f1430);display:grid;place-items:center;color:#fff;font-size:3.4rem;font-weight:800;position:relative}
.prof-card .pp img{width:100%;height:100%;object-fit:cover}
.prof-body{padding:24px;position:relative} .prof-body h3{margin:0 0 2px} .prof-role{color:var(--red);font-weight:600;font-size:.9rem;margin-bottom:10px} .prof-body p{color:var(--muted);font-size:.9rem;line-height:1.65}
.prof-x{position:absolute;top:12px;right:14px;border:none;background:none;font-size:1.5rem;cursor:pointer;color:var(--muted)}
@media(max-width:560px){.prof-card{grid-template-columns:1fr}.prof-card .pp{height:180px;font-size:2.6rem}}
/* Nembe.ai */
.ai-shell{display:grid;grid-template-columns:1fr 300px;gap:18px} @media(max-width:860px){.ai-shell{grid-template-columns:1fr}}
.ai-box{background:var(--glass);border:1px solid var(--line);border-radius:18px;display:flex;flex-direction:column;height:560px;box-shadow:var(--shadow-soft)}
.ai-msgs{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px}
.ai-msg{max-width:80%;padding:11px 14px;border-radius:14px;font-size:.92rem;line-height:1.55} .ai-msg.bot{background:var(--glass-3);align-self:flex-start;border-bottom-left-radius:4px}
.ai-msg.user{background:linear-gradient(135deg,var(--navy),#33406b);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.ai-in{display:flex;gap:8px;padding:14px;border-top:1px solid var(--line-2)} .ai-in input{flex:1} .ai-chip{font-size:.76rem;padding:6px 10px;border:1px solid var(--line);border-radius:var(--pill);background:var(--glass);cursor:pointer}
.token-meter{background:var(--glass);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow-soft)}
.token-bar{height:12px;border-radius:8px;background:var(--line-2);overflow:hidden;margin:8px 0} .token-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--gold,#E8A23D))}
/* reporting */
.matrix{width:100%;border-collapse:collapse;font-size:.86rem} .matrix th,.matrix td{border:1px solid var(--line-2);padding:8px 10px;text-align:center} .matrix th:first-child,.matrix td:first-child{text-align:left}
.dot-y{color:var(--teal);font-weight:800} .dot-n{color:#c2c9d6}
.rep-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.up-zone{border:2px dashed var(--line);border-radius:14px;padding:22px;text-align:center;color:var(--muted);transition:.2s;cursor:pointer} .up-zone:hover{border-color:var(--red);color:var(--text);background:var(--glass-3)}
.recs li{margin:7px 0} .recs .rec-g{color:var(--teal);font-weight:700} .recs .rec-a{color:#d98a16;font-weight:700} .recs .rec-r{color:var(--red);font-weight:700}

/* ===== v9b: mobile hardening ===== */
@media(max-width:760px){
  .container .grid[style*="grid-template-columns"]{grid-template-columns:1fr !important}
  .hero h1{font-size:2rem}
  .hero-inner .lead,.banner .lead{font-size:1rem}
  .well-panel{right:12px;left:12px;width:auto}
  .well-fab{right:14px;bottom:14px}
  .rep-toolbar{width:100%;justify-content:flex-start}
  .cube-stage,.cube-globe{width:128px;height:128px}
  .spirit{grid-template-columns:repeat(2,1fr) !important}
  .ai-box{height:480px}
  table.matrix{font-size:.74rem}
}
@media(max-width:460px){.spirit{grid-template-columns:1fr !important}.stat-strip{grid-template-columns:repeat(2,1fr)}}

/* ===== v10: event gallery ===== */
.ev-grid .photo{height:210px;margin:0} .ev-grid .photo img{height:100%;width:100%;object-fit:cover}
.ev-up{border:2px dashed var(--line);border-radius:14px;padding:24px;text-align:center;color:var(--muted);cursor:pointer;transition:.2s}
.ev-up:hover{border-color:var(--red);color:var(--text);background:var(--glass-3)}

/* ===== v11: notifications, day-in-life, chat, login polish ===== */
.nb-bell{position:relative;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--glass);display:grid;place-items:center;cursor:pointer;color:var(--text)}
.nb-bell:hover{border-color:rgba(227,4,32,.4)} .nb-bell svg{width:18px;height:18px}
.nb-bell .badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--red);color:#fff;font-size:.64rem;font-weight:800;display:grid;place-items:center;border:2px solid #fff}
.notif-panel{position:fixed;top:62px;right:14px;width:392px;max-width:calc(100vw - 20px);max-height:80vh;background:var(--glass);border:1px solid var(--line);border-radius:16px;box-shadow:0 30px 70px -20px rgba(8,15,35,.5);z-index:1255;display:none;flex-direction:column;overflow:hidden;animation:wpop .2s ease}
.notif-panel.open{display:flex}
.notif-head{display:flex;justify-content:space-between;align-items:center;padding:13px 16px;border-bottom:1px solid var(--line-2)} .notif-head b{font-size:1rem}
.notif-ai{margin:12px 14px 6px;padding:14px;border-radius:13px;background:linear-gradient(135deg,rgba(33,40,68,.06),rgba(43,179,154,.10));border:1px solid var(--line-2)}
.notif-ai .who{display:flex;align-items:center;gap:8px;font-weight:800;font-size:.86rem;margin-bottom:6px;color:var(--navy)}
.dotpulse{width:8px;height:8px;border-radius:50%;background:var(--teal);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(43,179,154,.5)}70%{box-shadow:0 0 0 8px rgba(43,179,154,0)}100%{box-shadow:0 0 0 0 rgba(43,179,154,0)}}
.notif-ai p{margin:0;font-size:.88rem;line-height:1.55;color:var(--text)}
.notif-tabs{display:flex;gap:6px;padding:8px 14px 0} .notif-tab{font-size:.78rem;padding:6px 10px;border-radius:8px;cursor:pointer;color:var(--muted);border:1px solid transparent;background:none}
.notif-tab.on{background:var(--glass-3);color:var(--text);border-color:var(--line-2)}
.notif-list{overflow-y:auto;padding:8px 12px 12px} .notif-empty{padding:24px;text-align:center;color:var(--muted);font-size:.85rem}
.notif-item{display:flex;gap:10px;padding:10px;border-radius:10px;cursor:pointer;text-decoration:none;color:inherit;align-items:flex-start}
.notif-item:hover{background:var(--glass-3)} .notif-item .ni{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex:none;color:#fff}
.notif-item .ni svg{width:15px;height:15px} .notif-item .nt{font-weight:600;font-size:.85rem;line-height:1.3} .notif-item .nd{font-size:.77rem;color:var(--muted)} .notif-item .nsec{font-size:.66rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.notif-ask{display:flex;gap:8px;padding:11px 14px;border-top:1px solid var(--line-2)} .notif-ask input{flex:1}
.pri-r{background:var(--red)} .pri-a{background:#E8A23D} .pri-g{background:var(--teal)} .pri-i{background:var(--navy)}
/* day in life */
.dil-reel{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:4px 2px 14px;scrollbar-width:thin}
.dil-card{flex:0 0 286px;scroll-snap-align:start;border-radius:18px;overflow:hidden;position:relative;height:430px;box-shadow:var(--shadow-soft);background:#0f1430}
.dil-card img{width:100%;height:100%;object-fit:cover;transition:.4s} .dil-card:hover img{transform:scale(1.05)}
.dil-card .ov{position:absolute;inset:auto 0 0 0;padding:16px;background:linear-gradient(transparent,rgba(8,12,30,.88));color:#fff} .dil-card .ov b{display:block;font-size:1.02rem} .dil-card .ov span{font-size:.8rem;color:#cdd6ee}
.dil-card .who2{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:8px;color:#fff} .dil-card .who2 .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--red),#b40319);display:grid;place-items:center;font-size:.72rem;font-weight:800;border:2px solid rgba(255,255,255,.6)}
/* chat */
.chat-shell{display:grid;grid-template-columns:248px 1fr;border:1px solid var(--line);border-radius:16px;overflow:hidden;height:600px;background:var(--glass);box-shadow:var(--shadow-soft)}
.chat-list{border-right:1px solid var(--line-2);overflow-y:auto} .chat-list .lh{padding:12px 14px;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.chat-ch{display:flex;gap:9px;align-items:center;padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--line-2)} .chat-ch.on,.chat-ch:hover{background:var(--glass-3)} .chat-ch b{font-size:.86rem} .chat-ch .av{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:.72rem;font-weight:800;color:#fff;flex:none}
.chat-main{display:flex;flex-direction:column;min-width:0} .chat-top{padding:12px 16px;border-bottom:1px solid var(--line-2);font-weight:700}
.chat-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:var(--ink)}
.chat-msg{max-width:78%;padding:8px 12px;border-radius:13px;font-size:.9rem;background:#fff;align-self:flex-start;box-shadow:var(--shadow-soft)} .chat-msg.me{align-self:flex-end;background:linear-gradient(135deg,var(--navy),#33406b);color:#fff}
.chat-msg .mu{font-size:.7rem;color:var(--muted);margin-bottom:2px;font-weight:700} .chat-msg.me .mu{color:#cdd6ee} .chat-msg .att{display:inline-flex;gap:6px;align-items:center;margin-top:6px;font-size:.78rem;background:rgba(0,0,0,.08);padding:4px 8px;border-radius:8px}
.chat-compose{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line-2)} .chat-compose input[type=text]{flex:1}
@media(max-width:680px){.chat-shell{grid-template-columns:1fr;height:560px}.chat-list{display:none}}
/* login polish */
.login-split{display:grid;grid-template-columns:1.05fr .95fr;min-height:100vh}
.login-aside{position:relative;display:grid;place-items:center;overflow:hidden;background:#0b1024}
.login-aside .bgv{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}
.login-aside .lc{position:relative;z-index:2;text-align:center;color:#fff;padding:40px;max-width:440px}
.login-pane{display:grid;place-items:center;padding:40px}
@media(max-width:840px){.login-split{grid-template-columns:1fr}.login-aside{display:none}}
@media(max-width:760px){.notif-panel{top:58px;right:8px} .dil-card{flex-basis:230px;height:360px}}

/* ===== v12: login animated background + cube globe ===== */
.login-aside{background:linear-gradient(135deg,#0b1024,#16203f 48%,#3a0a12)}
.login-aside .bgv{display:none}
.login-aside .lbg{position:absolute;inset:-25%;z-index:0;filter:blur(8px);animation:aurora 16s ease-in-out infinite;
 background:radial-gradient(38% 38% at 24% 26%,rgba(227,4,32,.30),transparent 62%),radial-gradient(44% 44% at 80% 72%,rgba(43,179,154,.24),transparent 62%),radial-gradient(40% 40% at 62% 18%,rgba(47,111,208,.24),transparent 62%)}
.login-aside .lgrid{position:absolute;inset:0;z-index:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:44px 44px;-webkit-mask-image:radial-gradient(circle at 50% 40%,#000,transparent 76%);mask-image:radial-gradient(circle at 50% 40%,#000,transparent 76%)}
.login-aside .lc{position:relative;z-index:2}
@keyframes aurora{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-4%,3%) scale(1.1)}}
.login-badge{display:inline-flex;align-items:center;gap:8px;margin-top:24px;padding:9px 16px;border-radius:var(--pill);background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);color:#fff;font-weight:600;font-size:.85rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}

/* ===== v13: ensure Watch videos always render ===== */
.reveal:has(video){opacity:1 !important;transform:none !important}
.vid{aspect-ratio:16/9;object-fit:cover;min-height:220px;background:#0b1024}
@media(max-width:760px){.vid{min-height:180px}}
