/* cutta - visual + lighting hub
   Built on the cuttadj.com design language: pure black/white, Inter,
   uppercase letterspaced labels, pill buttons. Adds hub-specific
   components (glance grid, swatches, asset cards, cue sheet, rider tables)
   and a print mode so the page exports as a clean PDF visual rider. */

:root{
  --bg:#000;
  --fg:#fff;
  --muted:#9a9a9a;
  --dim:#666;
  --line:rgba(255,255,255,.14);
  --line-soft:rgba(255,255,255,.08);
  --card:#0a0a0a;
  --card-2:#0c0c0c;
  --accent:#ff2a2a;            /* live accent, confirm with cutta, used sparingly */
  --good:#5fd38a;
  --warn:#e2b25f;
  --maxw:1180px;
  --pad:clamp(20px,5vw,64px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--fg);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.label{font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted)}
.mono{font-variant-numeric:tabular-nums}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:16px var(--pad);
  background:linear-gradient(to bottom,rgba(0,0,0,.92),rgba(0,0,0,.55));
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line-soft);
}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:30px;width:auto;filter:invert(1)}
.brand .kicker{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);border-left:1px solid var(--line);padding-left:14px}
.head-nav{display:flex;gap:20px;align-items:center}
.head-nav a{font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.8;transition:opacity .2s}
.head-nav a:hover{opacity:1}
.head-cta{
  border:1px solid var(--fg);border-radius:999px;padding:9px 18px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;transition:background .2s,color .2s}
.head-cta:hover{background:var(--fg);color:#000}

/* ---------- hero ---------- */
.hero{padding:clamp(48px,8vw,96px) 0 clamp(28px,4vw,44px);border-bottom:1px solid var(--line-soft)}
.hero .eyebrow{font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.hero h1{font-size:clamp(34px,7vw,76px);line-height:.98;font-weight:700;letter-spacing:-.02em;margin:0 0 18px}
.hero h1 .thin{font-weight:300;color:var(--muted)}
.hero .lede{max-width:680px;color:#cfcfcf;font-size:clamp(15px,2.2vw,18px);margin:0 0 30px}
.hero-meta{display:flex;flex-wrap:wrap;gap:10px 26px;align-items:center;color:var(--muted);font-size:13px}
.hero-meta b{color:#fff;font-weight:600}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--fg);color:var(--fg);
  padding:13px 24px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;border-radius:999px;
  transition:background .2s,color .2s,transform .15s;cursor:pointer;background:none;font-family:inherit}
.btn:hover{background:var(--fg);color:#000}
.btn:active{transform:translateY(1px)}
.btn.solid{background:var(--fg);color:#000}
.btn.solid:hover{opacity:.85}
.btn.ghost{border-color:var(--line)}
.btn svg{width:15px;height:15px;fill:currentColor}

/* ---------- sections ---------- */
section{padding:clamp(48px,7vw,92px) 0;border-bottom:1px solid var(--line-soft)}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin:0 0 34px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(22px,3.4vw,32px);font-weight:700;letter-spacing:-.01em;margin:0}
.sec-head .num{font-size:12px;letter-spacing:.3em;color:var(--dim)}
.sec-sub{color:var(--muted);max-width:680px;margin:-18px 0 30px;font-size:15px}

/* ---------- at a glance ---------- */
.glance{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.glance .cell{background:var(--card);border:1px solid var(--line-soft);border-radius:14px;padding:20px}
.glance .cell .k{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.glance .cell .v{font-size:17px;font-weight:600;line-height:1.35}
.glance .cell .v small{display:block;font-weight:400;font-size:13px;color:var(--muted);margin-top:5px;letter-spacing:0;text-transform:none}
.glance .cell.flag{border-color:rgba(226,178,95,.4);background:rgba(226,178,95,.06)}
.glance .cell.flag .k{color:var(--warn)}

/* ---------- palette swatches ---------- */
.swatches{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
.swatch{border:1px solid var(--line-soft);border-radius:14px;overflow:hidden;background:var(--card);cursor:pointer;transition:transform .15s,border-color .2s}
.swatch:hover{transform:translateY(-2px);border-color:var(--line)}
.swatch .chip{height:96px;width:100%}
.swatch .meta{padding:13px 14px}
.swatch .meta .nm{font-size:13px;font-weight:600}
.swatch .meta .hx{font-size:12px;color:var(--muted);letter-spacing:.06em;margin-top:3px;display:flex;align-items:center;gap:7px}
.swatch .copied{color:var(--good)}

/* ---------- asset library ---------- */
.asset-group{margin-bottom:30px}
.asset-group h3{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--line-soft)}
.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.asset{background:var(--card);border:1px solid var(--line-soft);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:12px}
.asset .top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.asset .nm{font-size:15px;font-weight:600;line-height:1.3}
.asset .desc{font-size:13px;color:var(--muted);margin:0}
.asset .badges{display:flex;flex-wrap:wrap;gap:6px}
.badge{font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:4px 9px;border-radius:999px;border:1px solid var(--line);color:#cfcfcf}
.badge.alpha{border-color:rgba(95,211,138,.5);color:var(--good)}
.badge.codec{border-color:rgba(255,255,255,.28);color:#fff}
.asset .dl{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);transition:color .2s}
.asset .dl:hover{color:#fff}
.asset .dl svg{width:14px;height:14px;fill:currentColor}

/* ---------- cue sheet / energy map ---------- */
.cue{border:1px solid var(--line-soft);border-radius:16px;overflow:hidden}
.cue-row{display:grid;grid-template-columns:90px 1fr 120px 1.4fr;gap:18px;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line-soft)}
.cue-row:last-child{border-bottom:0}
.cue-row.head{background:var(--card);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.cue-row .t{font-weight:600;font-variant-numeric:tabular-nums}
.cue-row .seg{font-weight:600}
.cue-row .seg small{display:block;font-weight:400;color:var(--muted);font-size:12px;margin-top:3px}
.cue-row .seg .hero-tag{display:inline-block;margin-left:8px;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:#000;background:var(--accent);padding:2px 7px;border-radius:999px;vertical-align:middle}
.energy{display:flex;gap:4px;align-items:center}
.energy i{width:9px;height:18px;border-radius:2px;background:rgba(255,255,255,.14)}
.energy i.on{background:#fff}
.cue-row .color{display:flex;align-items:center;gap:9px;color:#cfcfcf;font-size:13px}
.cue-row .color .dot{width:14px;height:14px;border-radius:50%;border:1px solid rgba(255,255,255,.25);flex:0 0 auto}

/* ---------- two column (bring / need + do / dont) ---------- */
.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.panel{background:var(--card);border:1px solid var(--line-soft);border-radius:16px;padding:24px}
.panel h3{margin:0 0 16px;font-size:13px;letter-spacing:.18em;text-transform:uppercase}
.panel.good h3{color:var(--good)}
.panel.warn h3{color:var(--accent)}
.panel ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.panel li{position:relative;padding-left:26px;font-size:14px;color:#d4d4d4;line-height:1.45}
.panel li::before{position:absolute;left:0;top:0;font-size:14px}
.panel.good li::before{content:"✓";color:var(--good)}
.panel.warn li::before{content:"✕";color:var(--accent)}
.panel.neutral li::before{content:"→";color:var(--muted)}

/* ---------- spec / rider table ---------- */
.spec{width:100%;border-collapse:collapse;border:1px solid var(--line-soft);border-radius:16px;overflow:hidden}
.spec tr{border-bottom:1px solid var(--line-soft)}
.spec tr:last-child{border-bottom:0}
.spec th{text-align:left;width:30%;padding:16px 20px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:500;vertical-align:top;background:var(--card)}
.spec td{padding:16px 20px;font-size:14.5px;color:#e6e6e6;vertical-align:top}
.spec td b{color:#fff}
.spec td small{color:var(--muted)}

/* ---------- checklist ---------- */
.check{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.check .item{display:flex;gap:13px;align-items:flex-start;background:var(--card);border:1px solid var(--line-soft);border-radius:12px;padding:16px 18px}
.check .item .box{width:18px;height:18px;border:1.5px solid var(--muted);border-radius:5px;flex:0 0 auto;margin-top:2px}
.check .item .tx{font-size:14px;color:#d8d8d8;line-height:1.4}
.check .item .tx b{color:#fff;display:block;margin-bottom:2px}
.check .when{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-top:4px}

/* ---------- contact ---------- */
.contact{display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px}
.contact .name{font-size:clamp(13px,2vw,15px);letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.contact .email{font-size:clamp(24px,4.5vw,42px);font-weight:700;letter-spacing:-.01em}
.contact .email:hover{text-decoration:underline}

/* ---------- footer ---------- */
.site-footer{padding:36px var(--pad) 60px;text-align:center;color:var(--muted);font-size:13px}
.site-footer .small{font-size:12px;color:var(--dim);margin-top:8px}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);
  background:#fff;color:#000;padding:11px 20px;border-radius:999px;font-size:13px;font-weight:600;
  letter-spacing:.02em;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:200;box-shadow:0 14px 40px rgba(0,0,0,.5)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- responsive ---------- */
@media(max-width:820px){
  .head-nav{display:none}
  .two{grid-template-columns:1fr}
  .cue-row{grid-template-columns:64px 1fr;gap:10px 14px;padding:16px}
  .cue-row .energy{grid-column:1;justify-self:start}
  .cue-row .color{grid-column:2}
  .cue-row.head{display:none}
  .cue-row .seg{grid-column:2}
  .cue-row .t{grid-column:1}
}

/* ---------- print: export as a clean PDF visual rider ---------- */
@media print{
  @page{margin:14mm}
  :root{--bg:#fff;--fg:#000;--muted:#555;--dim:#777;--card:#fff;--line:#bbb;--line-soft:#ddd}
  body{background:#fff;color:#000}
  .site-header,.head-nav,.head-cta,.hero-actions,.toast,.no-print{display:none !important}
  section{padding:18px 0;border-bottom:1px solid #ddd;break-inside:avoid}
  .swatch,.asset,.glance .cell,.panel,.check .item,.cue,.spec{border-color:#ccc !important;background:#fff !important}
  .brand img{filter:none}
  a{color:#000}
  .hero{padding:0 0 18px}
  .badge{border-color:#999;color:#333}
  .energy i{background:#ddd}.energy i.on{background:#000}
}
