/* ============================================================
   UNIC EVOLVE — Tour Companion · DARK
   Evolve brand: Violet #93278F · deep-space · cyan #00B0DA
   Left vertical sidebar · large Jost display · editorial dark UI
   ============================================================ */

:root{
  --violet:#93278F;--violet-300:#C46FBC;--violet-200:#E5C8E0;
  --cyan:#00B0DA;--cyan-glow:#5BD3F0;
  --unic-red:#BD081B;--amber:#F9B41B;

  --bg:#07071A;--bg-2:#0B0E2A;
  --panel:#0E1233;--panel-2:#161A45;--panel-3:#1E2360;
  --sidebar:#050510;
  --line:rgba(255,255,255,.09);
  --line-2:rgba(255,255,255,.16);

  --text:#F3F2F8;--text-2:rgba(243,242,248,.64);--text-3:rgba(243,242,248,.42);

  --r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:20px;--r-2xl:28px;--r-pill:999px;
  --shadow:0 10px 40px rgba(0,0,0,.4);
  --glow-violet:0 0 0 1px rgba(147,39,143,.5),0 8px 30px rgba(147,39,143,.28);

  --grad-hero:
    radial-gradient(60% 80% at 0% 40%, rgba(189,8,153,.5) 0%, transparent 60%),
    radial-gradient(70% 90% at 100% 60%, rgba(0,176,218,.4) 0%, transparent 65%),
    linear-gradient(180deg,#07071A 0%,#0B0E2A 55%,#07071A 100%);
  --grad-violet-deep:linear-gradient(135deg,#0B0E2A 0%,#2B0A4A 50%,#7B096B 100%);

  --sidew:280px;
  --headline:'Jost','Century Gothic','Avenir Next',-apple-system,system-ui,sans-serif;
  --body:'Jost','Helvetica Neue',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
  --safe-top:env(safe-area-inset-top,0px);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:var(--body);color:var(--text);background:var(--bg);line-height:1.6;
  font-weight:300;-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(80% 60% at 100% 0%,rgba(30,35,96,.5),transparent 60%);
  background-attachment:fixed;
}
a{color:var(--violet-300);text-decoration:none}
[hidden]{display:none !important}
img{max-width:100%}
::selection{background:rgba(147,39,143,.4)}

.eyebrow{font-family:var(--mono);text-transform:uppercase;letter-spacing:.22em;font-size:11px;color:var(--cyan-glow);font-weight:500;margin:0 0 12px}
.mono{font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em}

/* ============================================================
   GATE
   ============================================================ */
.gate{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}
.gate::before{content:"";position:absolute;inset:0;background:var(--grad-hero)}
.gate-card{
  position:relative;background:rgba(11,14,42,.5);border:1px solid var(--line-2);
  -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  border-radius:var(--r-2xl);padding:44px 30px 32px;width:100%;max-width:380px;text-align:center;box-shadow:var(--shadow);
}
.gate-logo{display:flex;justify-content:center;margin-bottom:22px}
.gate-logo img{height:40px}
.gate h1{font-family:var(--headline);font-weight:300;font-size:25px;margin:0 0 6px;letter-spacing:.01em}
.gate-sub{color:var(--text-2);font-size:13px;margin:0 0 26px}
#gate-form{display:flex;flex-direction:column;gap:11px}
#gate-input{padding:15px 18px;border:1.5px solid var(--line-2);border-radius:var(--r-pill);font-size:16px;font-family:var(--body);outline:none;background:rgba(255,255,255,.06);color:#fff;transition:.15s}
#gate-input::placeholder{color:var(--text-3)}
#gate-input:focus{border-color:var(--cyan)}
#gate-form button{padding:15px;border:none;border-radius:var(--r-pill);background:var(--violet);color:#fff;font-family:var(--headline);font-size:15px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;box-shadow:var(--glow-violet)}
#gate-form button:active{background:#7B096B}
.gate-error{color:var(--cyan-glow);font-size:13px;margin:14px 0 0}

/* ============================================================
   LAYOUT — sidebar + main
   ============================================================ */
.mtop{display:none}

.sidebar{
  position:fixed;top:0;left:0;z-index:60;width:var(--sidew);height:100%;
  background:var(--sidebar);border-right:1px solid var(--line);
  display:flex;flex-direction:column;overflow:hidden;
}
.side-brand{display:block;padding:28px 24px 20px;border-bottom:1px solid var(--line);flex:none}
.side-brand img{height:40px;display:block}
.side-sub{display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3);margin-top:12px}
.sidenav{flex:1;overflow-y:auto;padding:14px 0 28px;-webkit-overflow-scrolling:touch}
.sidenav::-webkit-scrollbar{width:7px}
.sidenav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:9px}

.nav-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-3);padding:18px 24px 8px}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:11px 24px;color:var(--text-2);font-size:14.5px;font-weight:300;
  border-left:2px solid transparent;transition:.12s;
}
.nav-item .ni-ic{font-size:15px;width:18px;text-align:center;opacity:.7;flex:none}
.nav-item:hover{color:var(--text);background:rgba(255,255,255,.03)}
.nav-item.active{color:#fff;border-left-color:var(--violet);background:linear-gradient(90deg,rgba(147,39,143,.18),transparent)}
.nav-item.active .ni-ic{opacity:1;color:var(--cyan-glow)}

/* tour stop list in sidebar */
.nav-stop{display:flex;align-items:center;gap:11px;padding:8px 24px;color:var(--text-2);font-size:13px;font-weight:300;border-left:2px solid transparent;transition:.12s}
.nav-stop .num{font-family:var(--mono);font-size:10.5px;color:var(--text-3);width:20px;flex:none;text-align:right}
.nav-stop .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-stop:hover{color:var(--text);background:rgba(255,255,255,.03)}
.nav-stop.active{color:#fff;border-left-color:var(--cyan);background:linear-gradient(90deg,rgba(0,176,218,.16),transparent)}
.nav-stop.active .num{color:var(--cyan-glow)}

.side-scrim{position:fixed;inset:0;z-index:55;background:rgba(0,0,0,.6)}

/* export buttons in the sidebar header */
.side-export{display:flex;gap:8px;padding:14px 18px;border-bottom:1px solid var(--line);flex:none}
.exp-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 8px;border:1px solid var(--line-2);border-radius:var(--r-md);background:rgba(255,255,255,.04);color:var(--text);font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:.14s}
.exp-btn:hover{border-color:var(--violet);background:rgba(147,39,143,.14);color:#fff}
.exp-btn:disabled{opacity:.5;cursor:default}

/* main */
.view{margin-left:var(--sidew);max-width:880px;padding:40px 48px 80px;padding-left:max(48px,calc((100vw - var(--sidew) - 880px)/2 + 48px))}

h1.page-title{font-family:var(--headline);font-weight:300;font-size:clamp(2.1rem,4.5vw,3.1rem);line-height:1.05;margin:0 0 10px;letter-spacing:-.015em}
.page-lead{color:var(--text-2);font-size:17px;margin:0 0 28px;max-width:60ch;font-weight:300}

/* ============================================================
   HERO (intro)
   ============================================================ */
.hero{position:relative;border-radius:var(--r-2xl);overflow:hidden;margin-bottom:26px;min-height:64vh;display:flex;align-items:flex-end;box-shadow:var(--shadow)}
.hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero .hero-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,7,26,.25) 0%,rgba(7,7,26,.55) 55%,rgba(7,7,26,.94) 100%)}
.hero-content{position:relative;padding:40px 36px 34px;width:100%}
.hero img.wordmark{height:40px;margin-bottom:22px;filter:drop-shadow(0 2px 12px rgba(0,0,0,.5))}
.hero h1{font-family:var(--headline);font-weight:300;font-size:clamp(2.6rem,6vw,4.4rem);line-height:1;margin:0 0 14px;letter-spacing:-.02em}
.hero p{margin:0;color:rgba(255,255,255,.86);font-size:17px;max-width:46ch;font-weight:300}
.hero-meta{display:flex;gap:30px;margin-top:26px}
.hero-meta b{display:block;font-family:var(--headline);font-weight:300;font-size:28px;letter-spacing:-.02em;background:linear-gradient(90deg,#fff,var(--cyan-glow));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-meta span{font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:16px 22px;border-radius:var(--r-pill);font-family:var(--headline);font-weight:500;font-size:15px;letter-spacing:.03em;text-transform:uppercase;background:var(--violet);color:#fff;width:100%;border:none;cursor:pointer;box-shadow:var(--glow-violet);transition:.15s}
.btn:hover{background:#a52e9f;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn.secondary{background:transparent;color:#fff;border:1.5px solid var(--line-2);box-shadow:none}
.btn.secondary:hover{border-color:var(--violet);background:rgba(147,39,143,.12)}
.btn.ghost{background:rgba(255,255,255,.06);color:var(--text);box-shadow:none}
.btn.ghost:hover{background:rgba(255,255,255,.1)}

.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.btn-row .btn{width:auto;flex:1;min-width:200px}

/* ============================================================
   CARDS / lists
   ============================================================ */
.grid{display:grid;gap:12px;margin-top:18px}
.list-head{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-3);margin:30px 2px 10px}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;color:var(--text);display:block;transition:.14s}
.nav-card{display:flex;align-items:center;gap:16px}
.nav-card:hover{border-color:var(--line-2);background:var(--panel-2);transform:translateY(-1px)}
.nav-card .idx{font-family:var(--headline);font-weight:400;font-size:14px;color:#fff;background:rgba(255,255,255,.08);min-width:42px;height:38px;padding:0 6px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex:none}
.nav-card.is-vision .idx{background:linear-gradient(135deg,var(--violet),#5a1657);color:#fff}
.nav-card .nc-body{flex:1;min-width:0}
.nav-card .nc-title{font-weight:400;font-size:17px;line-height:1.3}
.nav-card .nc-sub{color:var(--text-3);font-size:12.5px;display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.nav-card .chev{color:var(--text-3);font-size:22px;flex:none}

.pill{display:inline-flex;align-items:center;gap:4px;background:rgba(255,255,255,.07);color:var(--text-2);border-radius:var(--r-pill);padding:3px 11px;font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;white-space:nowrap}
.pill.time{background:rgba(147,39,143,.2);color:var(--violet-300)}

/* ============================================================
   DETAIL / STOP
   ============================================================ */
.detail-head{margin-bottom:18px}
.detail-floor{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;font-size:11px;color:var(--cyan-glow)}
.detail-head h1{font-family:var(--headline);font-weight:300;font-size:clamp(1.9rem,4vw,2.7rem);line-height:1.08;margin:8px 0 12px;letter-spacing:-.015em}
.detail-meta{display:flex;gap:8px;flex-wrap:wrap}
.back-link{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-2);margin-top:4px}
.back-link:hover{color:var(--cyan-glow)}

.stop-image{width:100%;aspect-ratio:16/9;border-radius:var(--r-xl);object-fit:cover;background:var(--panel);margin:6px 0 22px;display:block;border:1px solid var(--line)}
.stop-image.placeholder{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;text-align:center;padding:24px;background:var(--grad-violet-deep);border:none}
.stop-image.placeholder img{height:40px;opacity:.92}
.stop-image.placeholder small{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.55)}

.mode-toggle{display:flex;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:var(--r-pill);padding:4px;margin:0 0 22px;max-width:420px}
.mode-toggle button{flex:1;border:none;background:transparent;padding:10px;border-radius:var(--r-pill);font-family:var(--headline);font-size:14px;font-weight:400;color:var(--text-2);cursor:pointer;transition:.14s}
.mode-toggle button.active{background:var(--violet);color:#fff}

.checklist{list-style:none;padding:0;margin:0 0 8px}
.checklist li{display:flex;gap:14px;align-items:flex-start;padding:15px 4px;border-bottom:1px solid var(--line)}
.checklist .box{width:24px;height:24px;border-radius:var(--r-sm);border:2px solid var(--line-2);flex:none;margin-top:1px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;cursor:pointer;transition:.12s}
.checklist li.done .box{background:var(--violet);border-color:var(--violet)}
.checklist li.done .ct{color:var(--text-3);text-decoration:line-through}
.checklist .ct{font-size:16px;line-height:1.45}

.script p{font-size:18px;line-height:1.68;margin:0 0 18px;color:var(--text);font-weight:300}
.script-card{border-left:2px solid var(--violet);padding:4px 0 4px 22px}
.vision-body p{font-size:18px;line-height:1.68;margin:0 0 18px;font-weight:300}

.note{display:flex;gap:11px;background:rgba(249,180,27,.08);border:1px solid rgba(249,180,27,.3);border-radius:var(--r-md);padding:13px 15px;margin:6px 0 20px;font-size:14px;color:#f0c373;line-height:1.5}
.note .ni{flex:none}

.stepnav{display:flex;gap:12px;margin-top:30px;border-top:1px solid var(--line);padding-top:22px}
.stepnav a{flex:1;display:flex;flex-direction:column;color:var(--text);min-width:0;padding:6px 0}
.stepnav a.next{text-align:right;align-items:flex-end}
.stepnav .sn-label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3)}
.stepnav .sn-title{font-size:16px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;margin-top:4px}
.stepnav a.next .sn-title{color:var(--violet-300)}
.stepnav a.disabled{opacity:.35;pointer-events:none}

.progress{height:4px;background:rgba(255,255,255,.08);border-radius:var(--r-pill);overflow:hidden;margin:0 0 10px}
.progress i{display:block;height:100%;background:linear-gradient(90deg,var(--violet),var(--cyan));border-radius:var(--r-pill)}
.progress-label{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--text-3);margin:0 0 16px}

/* labs */
.kit{display:flex;flex-wrap:wrap;gap:7px;margin:12px 0 0}
.lab-what{font-size:16px;color:var(--text);margin:12px 0 0;line-height:1.6;font-weight:300}
.lab-talk{font-size:15px;color:#fff;background:rgba(147,39,143,.16);border:1px solid rgba(147,39,143,.3);border-radius:var(--r-md);padding:13px 15px;margin:16px 0 0;line-height:1.5}

/* partners */
.partner{display:flex;gap:16px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--line)}
.partner .pmark{width:48px;height:48px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--violet),#4d1248);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--headline);font-weight:400;font-size:16px;flex:none}
.partner h3{font-size:19px;margin:0 0 4px;font-weight:400}
.partner p{font-size:15px;color:var(--text-2);margin:0;line-height:1.55;font-weight:300}
.partner .tag{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--cyan-glow)}

/* facts */
.facts-group{margin-bottom:30px}
.facts-group h2{font-family:var(--headline);font-weight:400;font-size:14px;letter-spacing:.12em;margin:0 0 6px;color:var(--cyan-glow);text-transform:uppercase}
.fact-row{display:flex;gap:18px;padding:14px 2px;border-bottom:1px solid var(--line)}
.fact-row .fk{font-weight:400;font-size:15px;width:34%;flex:none;color:#fff}
.fact-row .fv{font-size:15px;color:var(--text-2);flex:1;font-weight:300}
.fact-row.warn .fk{color:var(--amber)}
.fact-row.warn .fv{color:#e0b878}

/* howto / route */
.howto{font-size:16.5px;line-height:1.65}
.howto ul{padding-left:20px;margin:0}
.howto li{margin-bottom:13px;font-weight:300}
.howto b{font-weight:500;color:#fff}
.route-list{counter-reset:r;list-style:none;padding:0;margin:16px 0 0}
.route-list li{counter-increment:r;display:flex;gap:14px;align-items:center;padding:13px 2px;border-bottom:1px solid var(--line);font-size:15.5px;font-weight:300}
.route-list li::before{content:counter(r);font-family:var(--mono);font-size:12px;color:var(--cyan-glow);width:24px;flex:none}

.foot-note{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--text-3);margin:34px 0 6px;line-height:1.7;text-transform:uppercase}

/* ============================================================
   MOBILE
   ============================================================ */
@media(max-width:899px){
  .mtop{
    display:flex;align-items:center;gap:10px;position:sticky;top:0;z-index:40;
    padding:calc(var(--safe-top) + 12px) 14px 12px;
    background:rgba(5,5,16,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);
  }
  .mtop-menu{border:none;background:transparent;color:#fff;font-size:23px;width:42px;height:42px;border-radius:var(--r-md);cursor:pointer}
  .mtop-menu:active{background:rgba(255,255,255,.08)}
  .mtop-brand img{height:30px;display:block}
  .mtop-spacer{width:42px}
  .sidebar{transform:translateX(-100%);transition:transform .26s cubic-bezier(.16,1,.3,1);width:84%;max-width:320px}
  .sidebar.open{transform:translateX(0);box-shadow:0 0 50px rgba(0,0,0,.6)}
  .view{margin-left:0;padding:24px 18px 60px}
  .hero{min-height:58vh}
  .btn-row .btn{min-width:100%}
}
@media(min-width:900px){
  .side-scrim{display:none !important}
}

/* ============================================================
   PRINT  -  light, well-formatted PDF (Download as PDF -> Save as PDF)
   ============================================================ */
#print-root{display:none}
@media print{
  @page{margin:18mm 16mm}
  html,body{background:#fff !important;color:#16161c !important}
  .sidebar,.mtop,.side-scrim,#view,#gate{display:none !important}
  #print-root{display:block !important;font-family:"Helvetica Neue","Segoe UI",Arial,sans-serif;color:#16161c}
  #print-root *{-webkit-print-color-adjust:exact;print-color-adjust:exact}

  /* ---- cover ---- */
  .pr-cover{position:relative;text-align:center;height:247mm;display:flex;flex-direction:column;
    align-items:center;justify-content:center;page-break-after:always}
  .pr-band{position:absolute;top:-18mm;left:-16mm;right:-16mm;height:9mm;
    background:linear-gradient(90deg,#7B096B,#93278F 45%,#00B0DA)}
  .pr-cover .pr-logo{height:58px;margin:0 0 26mm}
  .pr-cover .pr-kicker{font-family:"JetBrains Mono",monospace;font-size:10pt;letter-spacing:.3em;
    text-transform:uppercase;color:#93278F;margin:0 0 10pt}
  .pr-cover h1{font-family:"Jost","Century Gothic",sans-serif;font-weight:300;font-size:50pt;
    letter-spacing:-.5pt;line-height:.98;color:#14141c;margin:0 0 14pt}
  .pr-cover .pr-sub{font-family:"Jost",sans-serif;font-weight:300;font-size:14.5pt;line-height:1.45;
    color:#52565a;max-width:135mm;margin:0 auto 16pt}
  .pr-cover .rule{width:34mm;height:3px;background:#93278F;margin:0 auto 16pt}
  .pr-cover .pr-meta{font-family:"JetBrains Mono",monospace;font-size:9.5pt;letter-spacing:.14em;
    text-transform:uppercase;color:#8A8E94}

  /* ---- sections ---- */
  .pr-section{page-break-before:always}
  .pr-h2{font-family:"Jost",sans-serif;font-weight:400;font-size:24pt;letter-spacing:-.3pt;color:#14141c;
    margin:0 0 16pt;padding:0 0 7pt;border-bottom:2.5px solid #93278F}
  .pr-item{page-break-inside:avoid;margin:0 0 20pt}
  .pr-eyebrow{font-family:"JetBrains Mono",monospace;font-size:8pt;letter-spacing:.18em;
    text-transform:uppercase;color:#93278F;margin:0 0 4pt}
  .pr-item h3{font-family:"Jost",sans-serif;font-weight:500;font-size:15pt;letter-spacing:-.2pt;
    color:#14141c;margin:0 0 4pt}
  .pr-item .meta{font-family:"JetBrains Mono",monospace;font-size:8.5pt;letter-spacing:.06em;
    text-transform:uppercase;color:#8A8E94;margin:0 0 8pt}
  .pr-item p{font-size:11pt;line-height:1.55;margin:0 0 7pt;color:#2a2a33}
  .pr-item ul{margin:8pt 0 0 0;padding-left:0;list-style:none}
  .pr-item li{font-size:10pt;line-height:1.45;margin:0 0 5pt;padding-left:16pt;position:relative;color:#2a2a33}
  .pr-item li::before{content:"";position:absolute;left:0;top:5.5pt;width:5pt;height:5pt;
    border-radius:50%;background:#93278F}
  .pr-img{display:block;width:100%;max-height:82mm;object-fit:cover;border-radius:8px;
    border:1px solid #e4e6ea;margin:0 0 10pt}
  .pr-facts{width:100%;border-collapse:collapse;margin:2pt 0 0}
  .pr-facts td{border:1px solid #e4e6ea;padding:6pt 9pt;font-size:9.5pt;line-height:1.4;vertical-align:top;color:#2a2a33}
  .pr-facts td.k{font-family:"Jost",sans-serif;font-weight:500;width:33%;background:#faf3f8;color:#14141c}
  .pr-note{font-size:9pt;color:#8a5d1b;background:#fdf6ec;border:1px solid #f3e0c2;
    border-radius:6px;padding:6pt 9pt;margin:0 0 8pt}
}
