/* Shot Lab — App-specific styles
 * Loaded alongside /css/main.css on camera-moves.html
 */
:root{
    --ink:#0c0c0e; --panel:#15151a; --panel2:#1c1c22; --line:#2a2a32;
    --bone:#ece8df; --dust:#8d8a82; --amber:#e0a84b; --red:#d6473a; --green:#7bb274;
    --disp:"Bebas Neue", "Arial Narrow", sans-serif;
    --body:"Space Grotesk", system-ui, sans-serif;
    --mono:"JetBrains Mono", ui-monospace, monospace;
  }
  *{box-sizing:border-box}
  html,body{margin:0;background:var(--ink);color:var(--bone);font-family:var(--body)}
  body{-webkit-font-smoothing:antialiased}
  a{color:var(--amber)}
  ::selection{background:var(--amber);color:#000}

  /* ---- header / clapper ---- */
  header{
    border-bottom:1px solid var(--line);
    background:
      repeating-linear-gradient(135deg,#0c0c0e 0 22px,#17171c 22px 44px) ;
    padding:18px 22px 0;
  }
  .clap{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}
  .title{font-family:var(--disp);font-size:clamp(38px,6vw,62px);line-height:.82;letter-spacing:.5px;margin:0}
  .title b{color:var(--amber);font-weight:400}
  .sub{font-family:var(--mono);font-size:11px;color:var(--dust);letter-spacing:.16em;text-transform:uppercase;margin:0 0 6px}
.tab{
    font-family:var(--disp);font-size:22px;letter-spacing:1px;color:var(--dust);
    background:none;border:1px solid var(--line);border-bottom:none;
    padding:9px 20px;cursor:pointer;border-radius:6px 6px 0 0;margin-right:6px;
    transition:color .15s,background .15s;
  }
.tab.on{color:#000;background:var(--amber);border-color:var(--amber)}

.view.on{display:block}

/* ---- category pills ---- */
  .pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
  .pill{
    font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
    color:var(--dust);background:var(--panel);border:1px solid var(--line);
    padding:7px 13px;border-radius:999px;cursor:pointer;transition:.15s;
  }
  .pill:hover{color:var(--bone);border-color:#3a3a44}
  .pill.on{color:#000;background:var(--bone);border-color:var(--bone)}

  /* ---- contact sheet grid ---- */
  .grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:14px}
  .card{
    background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden;
    cursor:pointer;transition:border-color .15s,transform .12s,box-shadow .15s;position:relative;
  }
  .card:hover{border-color:#3d3d48;transform:translateY(-2px)}
  .card.sel{border-color:var(--amber);box-shadow:0 0 0 1px var(--amber)}
  .card.sel .num{background:var(--amber);color:#000}

  /* demo stage */
  .stage{height:120px;background:#08080a;position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
  .frame{position:absolute;inset:0}
  .grid-floor{position:absolute;left:-20%;right:-20%;bottom:0;height:55%;
    background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
    background-size:28px 18px;transform:perspective(220px) rotateX(58deg);transform-origin:bottom;opacity:.5}
  .subj{position:absolute;left:50%;top:50%;width:26px;height:54px;margin:-30px 0 0 -13px;border-radius:8px 8px 4px 4px;
    background:linear-gradient(180deg,var(--amber),#9c6f1f)}
  .subj::after{content:"";position:absolute;left:50%;top:-13px;width:15px;height:15px;margin-left:-7.5px;border-radius:50%;background:var(--amber)}
  .lens{position:absolute;left:8px;top:8px;width:14px;height:14px;border:2px solid var(--bone);border-radius:50%;opacity:.7}
  .lens::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--bone)}

  /* per-move demo animations driven by data-demo */
  .card .frame{animation:none}
  [data-demo="pan"] .grid-floor{animation:d-pan 3.2s ease-in-out infinite alternate}
  @keyframes d-pan{from{transform:perspective(220px) rotateX(58deg) translateX(40px)}to{transform:perspective(220px) rotateX(58deg) translateX(-40px)}}
  [data-demo="pan"] .subj{animation:d-pan-s 3.2s ease-in-out infinite alternate}
  @keyframes d-pan-s{from{transform:translateX(34px)}to{transform:translateX(-34px)}}

@keyframes d-tilt{from{transform:translateY(-20px)}to{transform:translateY(18px)}}

  [data-demo="dollyin"] .subj{animation:d-in 3.2s ease-in-out infinite alternate}
  @keyframes d-in{from{transform:scale(.7)}to{transform:scale(1.35)}}
  [data-demo="dollyout"] .subj{animation:d-out 3.2s ease-in-out infinite alternate}
  @keyframes d-out{from{transform:scale(1.35)}to{transform:scale(.7)}}

  [data-demo="truck"] .subj{animation:d-truck 3s ease-in-out infinite alternate}
  @keyframes d-truck{from{transform:translateX(-48px)}to{transform:translateX(48px)}}
  [data-demo="truck"] .grid-floor{animation:d-truckf 3s ease-in-out infinite alternate}
  @keyframes d-truckf{from{transform:perspective(220px) rotateX(58deg) translateX(-30px)}to{transform:perspective(220px) rotateX(58deg) translateX(30px)}}

  [data-demo="pedestal"] .subj{animation:d-ped 3s ease-in-out infinite alternate}
  @keyframes d-ped{from{transform:translateY(26px) scale(1.05)}to{transform:translateY(-24px) scale(1.05)}}

  [data-demo="zoom"] .frame{animation:d-zoom 3.2s ease-in-out infinite alternate}
  @keyframes d-zoom{from{transform:scale(1)}to{transform:scale(1.55)}}

@keyframes d-crane{from{transform:translateY(22px) scale(1.1)}to{transform:translateY(-18px) scale(.85)}}

  [data-demo="arc"] .subj{animation:d-arc 4s linear infinite}
  @keyframes d-arc{0%{transform:rotateY(0) translateZ(0)}50%{transform:scaleX(.5) skewY(-6deg)}100%{transform:rotateY(360deg)}}
  [data-demo="arc"] .grid-floor{animation:d-arcf 4s linear infinite}
  @keyframes d-arcf{from{transform:perspective(220px) rotateX(58deg) rotate(0)}to{transform:perspective(220px) rotateX(58deg) rotate(20deg)}}

  [data-demo="dollyzoom"] .subj{animation:d-dz 3.4s ease-in-out infinite alternate}
  @keyframes d-dz{from{transform:scale(.9)}to{transform:scale(1.05)}}
  [data-demo="dollyzoom"] .grid-floor{animation:d-dzf 3.4s ease-in-out infinite alternate}
  @keyframes d-dzf{from{transform:perspective(220px) rotateX(58deg) scale(.6)}to{transform:perspective(140px) rotateX(58deg) scale(1.5)}}

  [data-demo="handheld"] .frame{animation:d-hand .35s steps(4) infinite}
  @keyframes d-hand{0%{transform:translate(0,0)}25%{transform:translate(2px,-2px) rotate(.4deg)}50%{transform:translate(-2px,1px) rotate(-.3deg)}75%{transform:translate(1px,2px)}100%{transform:translate(-1px,-1px) rotate(.2deg)}}

  [data-demo="steadi"] .frame{animation:d-steadi 4s ease-in-out infinite alternate}
  @keyframes d-steadi{from{transform:translateX(-12px) translateY(2px)}to{transform:translateX(12px) translateY(-2px)}}
  [data-demo="steadi"] .subj{animation:d-truck 4s ease-in-out infinite alternate}

  [data-demo="whip"] .frame{animation:d-whip 1.6s infinite}
  @keyframes d-whip{0%,40%{transform:translateX(0);filter:blur(0)}55%{transform:translateX(-60px);filter:blur(6px)}70%,100%{transform:translateX(-90px);filter:blur(0)}}

  [data-demo="follow"] .subj{animation:d-foll 3s ease-in-out infinite alternate}
  @keyframes d-foll{from{transform:translateX(-30px) scale(.95)}to{transform:translateX(30px) scale(.95)}}
  [data-demo="follow"] .grid-floor{animation:d-truckf 3s ease-in-out infinite alternate}

@keyframes d-air{from{transform:scale(1.4) translateY(10px)}to{transform:scale(.7) translateY(-14px)}}
[data-demo="static"] .lens{animation:d-blink 2.4s steps(1) infinite}
  @keyframes d-blink{0%,90%{opacity:.7}95%{opacity:.2}}

  [data-demo="roll"] .frame{animation:d-roll 4s ease-in-out infinite alternate}
  @keyframes d-roll{from{transform:rotate(-14deg)}to{transform:rotate(14deg)}}

@keyframes d-rack{from{filter:blur(5px);opacity:.6}to{filter:blur(0);opacity:1}}

  /* ---- extra scene props ---- */
  .subj2{position:absolute;left:50%;top:50%;width:26px;height:54px;margin:-30px 0 0 -13px;border-radius:8px 8px 4px 4px;background:linear-gradient(180deg,#7c8aa0,#3a4350);display:none}
  .subj2::after{content:"";position:absolute;left:50%;top:-13px;width:15px;height:15px;margin-left:-7.5px;border-radius:50%;background:#7c8aa0}
  .occ{position:absolute;top:0;bottom:0;left:0;width:74%;background:linear-gradient(90deg,#0a0a0c,#1c1c24);display:none;z-index:3}
  .ring{position:absolute;left:50%;top:50%;width:34px;height:34px;margin:-17px 0 0 -17px;border:3px solid var(--bone);border-radius:50%;display:none;opacity:.55;z-index:2}

  /* fast dolly / rush */
  [data-demo="fastdollyin"] .subj{animation:d-fastin 1.7s cubic-bezier(.6,0,.9,1) infinite}
  @keyframes d-fastin{0%{transform:scale(.5)}65%{transform:scale(1.7)}100%{transform:scale(1.7)}}

  /* macro + cosmic scale */
  [data-demo="macro"] .frame{animation:d-macro 3.6s ease-in infinite}
  @keyframes d-macro{0%{transform:scale(.9)}100%{transform:scale(4.2)}}
  [data-demo="cosmic"] .frame{animation:d-cosmic 4.6s ease-in-out infinite}
  @keyframes d-cosmic{0%{transform:scale(.22)}100%{transform:scale(2.7)}}

  /* over the shoulder */
  [data-demo="ots"] .subj2{display:block;left:20%;top:64%;width:66px;height:90px;filter:blur(2px);background:linear-gradient(180deg,#23272f,#121418)}
  [data-demo="ots"] .subj2::after{width:38px;height:38px;margin-left:-19px;top:-24px;background:#23272f}
  [data-demo="ots"] .subj{left:62%;animation:d-in 4s ease-in-out infinite alternate}

  /* fisheye */
  [data-demo="fisheye"] .stage{background:radial-gradient(circle at 50% 50%,#0c0c10 55%,#000 100%)}
  [data-demo="fisheye"] .subj{animation:d-fish 3.2s ease-in-out infinite alternate}
  @keyframes d-fish{from{transform:scaleX(1) scaleY(1)}to{transform:scaleX(1.4) scaleY(.85) translateY(4px)}}
  [data-demo="fisheye"] .grid-floor{transform:perspective(120px) rotateX(58deg) scale(1.4)}

  /* reveal from behind / wipe */
  [data-demo="wipe"] .occ{display:block;animation:d-wipe 3.6s ease-in-out infinite}
  @keyframes d-wipe{0%,38%{transform:translateX(0)}100%{transform:translateX(150%)}}

  /* through shot (fly through aperture) */
  [data-demo="through"] .ring{display:block;animation:d-through 2.9s ease-in infinite}
  @keyframes d-through{0%{transform:scale(.5);opacity:.8}100%{transform:scale(8);opacity:0}}
  [data-demo="through"] .subj{animation:d-in 2.9s ease-in infinite}

  /* reveal from blur */
  [data-demo="blur"] .subj{animation:d-blurr 3.4s ease-in-out infinite}
  @keyframes d-blurr{0%{filter:blur(8px);opacity:.35}60%,100%{filter:blur(0);opacity:1}}

  /* rack focus (two planes swap) */
  [data-demo="rackfocus"] .subj2{display:block;left:30%;top:60%;width:38px;height:70px}
  [data-demo="rackfocus"] .subj{left:68%;top:44%;width:18px;height:38px;margin:-19px 0 0 -9px}
  [data-demo="rackfocus"] .subj2{animation:d-rf-fg 3.4s ease-in-out infinite alternate}
  [data-demo="rackfocus"] .subj{animation:d-rf-bg 3.4s ease-in-out infinite alternate}
  @keyframes d-rf-fg{from{filter:blur(0)}to{filter:blur(5px)}}
  @keyframes d-rf-bg{from{filter:blur(5px)}to{filter:blur(0)}}

  /* tilt up / down (one-direction loops) */
  [data-demo="tiltup"] .subj{animation:d-tiltup 3s ease-out infinite}
  @keyframes d-tiltup{0%{transform:translateY(34px)}100%{transform:translateY(-30px)}}
  [data-demo="tiltdown"] .subj{animation:d-tiltdn 3s ease-out infinite}
  @keyframes d-tiltdn{0%{transform:translateY(-30px)}100%{transform:translateY(34px)}}

  /* slow cinematic arc */
  [data-demo="arcslow"] .subj{animation:d-arc 7s linear infinite}
  [data-demo="arcslow"] .grid-floor{animation:d-arcf 7s linear infinite}

  /* crane up / down */
  [data-demo="craneup"] .frame{animation:d-craneup 4s ease-in-out infinite}
  @keyframes d-craneup{0%{transform:translateY(22px) scale(1.12)}100%{transform:translateY(-20px) scale(.82)}}
  [data-demo="cranedown"] .frame{animation:d-cranedn 4s ease-in-out infinite}
  @keyframes d-cranedn{0%{transform:translateY(-20px) scale(.82)}100%{transform:translateY(22px) scale(1.12)}}

  /* snap / crash zoom */
  [data-demo="snap"] .frame{animation:d-snap 2.3s infinite}
  @keyframes d-snap{0%,28%{transform:scale(1)}38%{transform:scale(2.2)}88%{transform:scale(2.2)}100%{transform:scale(1)}}

  /* drone fly-over */
  [data-demo="droneover"] .grid-floor{transform:perspective(300px) rotateX(70deg) scale(1.4);animation:d-overf 2.4s linear infinite}
  @keyframes d-overf{from{background-position:0 0}to{background-position:0 36px}}
  [data-demo="droneover"] .subj{animation:d-overs 2.4s linear infinite}
  @keyframes d-overs{from{transform:translateY(-46px) scale(.5)}to{transform:translateY(46px) scale(.5)}}

  /* god's eye top-down */
  [data-demo="godseye"] .grid-floor{transform:none;inset:0;opacity:.35}
  [data-demo="godseye"] .subj{width:30px;height:30px;border-radius:50%;margin:-15px 0 0 -15px;background:radial-gradient(circle,var(--amber),#9c6f1f);animation:d-spin 6s linear infinite}
  [data-demo="godseye"] .subj::after{top:-2px;left:50%;width:6px;height:16px;margin-left:-3px;border-radius:3px}

  /* drone dive (FPV) */
  [data-demo="dive"] .frame{animation:d-dive 2.6s cubic-bezier(.5,0,1,1) infinite}
  @keyframes d-dive{0%{transform:scale(.45) translateY(-14px)}100%{transform:scale(2.3) translateY(22px)}}

  /* leading (subject walks toward us) */
  [data-demo="leading"] .subj{animation:d-bob 1s ease-in-out infinite}
  @keyframes d-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
  [data-demo="leading"] .grid-floor{animation:d-floorfwd 1.6s linear infinite}
  @keyframes d-floorfwd{from{background-position:0 0}to{background-position:0 18px}}

  /* following (subject moves away) */
  [data-demo="following"] .subj{animation:d-follaway 3s ease-in-out infinite alternate}
  @keyframes d-follaway{from{transform:scale(1.05) translateY(2px)}to{transform:scale(.8) translateY(-4px)}}
  [data-demo="following"] .grid-floor{animation:d-floorback 1.6s linear infinite}
  @keyframes d-floorback{from{background-position:0 18px}to{background-position:0 0}}

  /* POV walk (sway + bob) */
  [data-demo="pov"] .frame{animation:d-pov 1.5s ease-in-out infinite}
  @keyframes d-pov{0%{transform:translateX(-5px) rotate(-.7deg)}25%{transform:translateX(0) translateY(-4px)}50%{transform:translateX(5px) rotate(.7deg)}75%{transform:translateX(0) translateY(-4px)}100%{transform:translateX(-5px) rotate(-.7deg)}}
  [data-demo="pov"] .grid-floor{animation:d-floorfwd 1.1s linear infinite}

  @keyframes d-spin{to{transform:rotate(360deg)}}

  .meta{padding:13px 14px 15px}
  .top{display:flex;align-items:baseline;gap:8px}
  .num{font-family:var(--mono);font-size:10px;color:var(--dust);background:var(--panel2);border:1px solid var(--line);
    padding:2px 6px;border-radius:4px;letter-spacing:.05em}
  .name{font-family:var(--disp);font-size:24px;letter-spacing:.6px;line-height:1}
  .alias{font-family:var(--mono);font-size:10.5px;color:var(--amber);letter-spacing:.06em;margin:5px 0 8px}
  .desc{font-size:13.5px;line-height:1.5;color:#cdc9c0;margin:0 0 8px}
  .feel{font-size:12px;color:var(--dust);line-height:1.45}
  .feel b{color:var(--bone);font-weight:600}
  .check{position:absolute;top:10px;right:10px;width:22px;height:22px;border-radius:50%;border:1.5px solid var(--line);
    display:grid;place-items:center;font-size:13px;color:transparent;background:rgba(0,0,0,.4)}
  .card.sel .check{background:var(--amber);border-color:var(--amber);color:#000}

/* ---- 3D studio ---- */
  .studio{display:grid;grid-template-columns:1fr 320px;gap:16px;align-items:start}
  @media(max-width:880px){.studio{grid-template-columns:1fr}}
  .stagewrap{position:relative;background:#08080a;border:1px solid var(--line);border-radius:10px;overflow:hidden}
  #director{display:block;width:100%;height:460px}
  .povbox{position:absolute;right:12px;top:12px;width:172px;height:104px;border:1px solid var(--amber);
    border-radius:6px;overflow:hidden;background:#000;box-shadow:0 6px 20px rgba(0,0,0,.5)}
  #pov{display:block;width:100%;height:100%}
  .povbox .tag{position:absolute;left:6px;top:5px;font-family:var(--mono);font-size:9px;color:var(--amber);
    letter-spacing:.12em;text-shadow:0 0 4px #000}
  .reticle{position:absolute;inset:0;pointer-events:none}
  .reticle::before,.reticle::after{content:"";position:absolute;background:rgba(224,168,75,.5)}
  .reticle::before{left:50%;top:34%;bottom:34%;width:1px;margin-left:-.5px}
  .reticle::after{top:50%;left:40%;right:40%;height:1px;margin-top:-.5px}
  .hint{position:absolute;left:12px;bottom:10px;font-family:var(--mono);font-size:10px;color:var(--dust);
    letter-spacing:.06em;background:rgba(0,0,0,.5);padding:4px 8px;border-radius:5px}
  .rec{position:absolute;left:12px;top:12px;font-family:var(--mono);font-size:10px;color:var(--red);letter-spacing:.14em;
    display:none;align-items:center;gap:6px}
  .rec.on{display:flex}
  .rec .dot{width:8px;height:8px;border-radius:50%;background:var(--red);animation:blink 1s steps(1) infinite}
  @keyframes blink{50%{opacity:.2}}

  .panel-c{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px}
  .panel-c h3{font-family:var(--disp);font-size:22px;letter-spacing:.8px;margin:0 0 4px}
  .panel-c .small{font-size:12px;color:var(--dust);margin:0 0 14px;line-height:1.45}
  .slider{margin-bottom:14px}
  .slider .lab{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;
    letter-spacing:.08em;text-transform:uppercase;color:var(--dust);margin-bottom:5px}
  .slider .lab b{color:var(--amber);font-weight:500}
  input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:4px;border-radius:3px;background:var(--line);outline:none}
  input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;background:var(--amber);cursor:pointer;border:2px solid #000}
  input[type=range]::-moz-range-thumb{width:15px;height:15px;border-radius:50%;background:var(--amber);cursor:pointer;border:2px solid #000}
  .markrow{display:flex;gap:8px;margin-bottom:10px}
  .markrow .btn{flex:1;text-align:center;padding:9px 4px;font-size:12px}
  .marked{border-color:var(--green)!important;color:var(--green)!important}
  .readout{background:#0a0a0c;border:1px solid var(--line);border-radius:8px;padding:11px;margin-top:6px}
  .readout .det{font-family:var(--disp);font-size:21px;letter-spacing:.6px;color:var(--amber);min-height:24px}
  .readout .det.idle{color:var(--dust)}
  .readout textarea{width:100%;min-height:84px;margin-top:9px;resize:vertical;background:#000;border:1px solid var(--line);
    color:var(--green);font-family:var(--mono);font-size:12.5px;line-height:1.5;padding:10px;border-radius:7px;outline:none}
  .footer{margin-top:34px;border-top:1px solid var(--line);padding-top:14px;font-family:var(--mono);font-size:10.5px;color:var(--dust);letter-spacing:.05em}
  .toast{position:fixed;bottom:64px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--green);color:#000;
    font-family:var(--mono);font-size:12px;padding:9px 16px;border-radius:8px;opacity:0;transition:.25s;z-index:50;pointer-events:none}
  .toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
  @media (prefers-reduced-motion: reduce){*{animation-duration:.001s!important}}


  /* ===== generator / app shell (mobile-first) ===== */
  .wrap{max-width:760px;margin:0 auto;padding:18px 16px 70px}
  .gen{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 16px 18px;margin-bottom:18px}
  .section-h{font-family:var(--disp);font-size:27px;letter-spacing:.6px;margin:0 0 8px}
  .muted{color:var(--dust);font-size:13px;line-height:1.5;margin:0 0 14px}
  .tpl-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;margin:0 0 4px;scrollbar-width:thin}
  .tpl{flex:0 0 auto;font-family:var(--mono);font-size:12px;color:var(--bone);background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:9px 15px;cursor:pointer;white-space:nowrap;transition:.15s}
  .tpl:hover{border-color:var(--amber);color:var(--amber)}
  .lab{font-family:var(--mono);font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--dust);display:block;margin:15px 0 6px}
  .in,.sel{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--bone);font-family:var(--body);font-size:15px;padding:12px 13px;border-radius:9px;outline:none}
  .in:focus,.sel:focus{border-color:var(--amber)}
  .two{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  @media(max-width:520px){.two{grid-template-columns:1fr}}
  .models{display:flex;gap:6px;flex-wrap:wrap}
  .model{font-family:var(--mono);font-size:12px;color:var(--dust);background:var(--panel2);border:1px solid var(--line);padding:8px 13px;border-radius:8px;cursor:pointer;transition:.15s}
  .model:hover{color:var(--bone)}
  .model.on{background:var(--amber);color:#000;border-color:var(--amber);font-weight:600}
  .picker{border:1px solid var(--line);border-radius:9px;background:var(--panel2);padding:10px 11px;max-height:188px;overflow-y:auto}
  .pk-cat{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--dust);margin:9px 1px 5px}
  .pk-cat:first-child{margin-top:0}
  .pk-wrap{display:flex;flex-wrap:wrap;gap:6px}
  .pk{font-size:12px;color:var(--bone);background:var(--ink);border:1px solid var(--line);padding:6px 10px;border-radius:7px;cursor:pointer;transition:.12s}
  .pk:hover{border-color:#3d3d48}
  .pk.on{background:var(--amber);color:#000;border-color:var(--amber);font-weight:600}
  .sel-chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:10px;min-height:4px}
  .sel-chip{font-family:var(--mono);font-size:11px;background:var(--panel2);border:1px solid var(--amber);color:var(--bone);padding:5px 9px;border-radius:6px;display:flex;align-items:center;gap:7px}
  .sel-chip .h{cursor:grab;color:var(--dust)}
  .sel-chip button{background:none;border:none;color:var(--red);cursor:pointer;font-size:14px;line-height:1;padding:0}
  .gen-btn{width:100%;margin-top:18px;font-family:var(--disp);font-size:25px;letter-spacing:1px;background:var(--amber);color:#000;border:none;padding:13px;border-radius:11px;cursor:pointer;transition:.15s}
  .gen-btn:hover{filter:brightness(1.08)}
  .out-box{margin-top:14px}
  .out-box textarea{width:100%;min-height:118px;resize:vertical;background:#0a0a0c;border:1px solid var(--line);color:var(--green);font-family:var(--mono);font-size:13.5px;line-height:1.55;padding:13px;border-radius:10px;outline:none}
  .out-box textarea:focus{border-color:var(--amber)}
  .out-box.flash textarea{border-color:var(--amber);box-shadow:0 0 0 1px var(--amber)}
  .copy-btn{width:100%;margin-top:9px;font-family:var(--body);font-weight:600;font-size:14px;background:var(--panel2);color:var(--bone);border:1px solid var(--line);padding:12px;border-radius:9px;cursor:pointer}
  .copy-btn:hover{border-color:var(--amber)}
  .warns{margin-top:12px;display:flex;flex-direction:column;gap:7px}
  .warn{display:flex;gap:9px;align-items:flex-start;font-size:13px;line-height:1.4;border:1px solid;border-radius:9px;padding:9px 11px}
  .warn.w{background:rgba(214,71,58,.08);border-color:rgba(214,71,58,.42);color:#f0b3ac}
  .warn.t{background:rgba(224,168,75,.08);border-color:rgba(224,168,75,.42);color:#f0d29a}
  .warn .ic{font-family:var(--mono);font-weight:700;flex:0 0 auto;width:14px;text-align:center}
  .okline{margin-top:12px;font-size:13px;color:var(--green);display:flex;gap:8px;align-items:center}
  .adv{margin:0 0 22px;border:1px solid var(--line);border-radius:13px;background:var(--panel);overflow:hidden}
  .adv>summary{list-style:none;cursor:pointer;padding:15px 16px;font-family:var(--disp);font-size:23px;letter-spacing:.5px;display:flex;align-items:center;gap:10px}
  .adv>summary::-webkit-details-marker{display:none}
  .adv>summary .tagx{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--dust);background:var(--panel2);border:1px solid var(--line);padding:3px 8px;border-radius:999px}
  .adv>summary .chev{margin-left:auto;color:var(--dust);font-size:13px;transition:.2s}
  .adv[open]>summary .chev{transform:rotate(180deg)}
  .adv .adv-body{padding:0 16px 16px}
  .adv .adv-body #director{height:380px}
  .lib-head{margin:6px 0 4px}
  /* neutralise old full-width main padding if referenced */
  header{padding:16px 16px 16px}


  /* ---- improvement buttons ---- */
  .mod-row{display:none;flex-wrap:wrap;gap:7px;margin-top:10px;align-items:center}
  .mod-label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--dust)}
  .mod-btn{font-family:var(--body);font-size:12.5px;font-weight:600;background:var(--panel2);color:var(--bone);
    border:1px solid var(--line);padding:7px 12px;border-radius:7px;cursor:pointer;transition:.15s}
  .mod-btn:hover{border-color:var(--amber);color:var(--amber)}
  /* ---- why this works ---- */
  .why-box{background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:13px 15px;margin-top:11px}
  .why-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:7px}
  .why-list li{font-size:13px;line-height:1.45;display:flex;gap:8px}
  .why-ok{color:var(--green)}
  .why-warn{color:var(--amber)}
  .why-list strong{color:var(--bone)}
