/* ================================================================
   NHPT 3.0 KRAFT KINETIC — presentation layer
   Loads AFTER the legacy Kraft Monolith site.css (content classes,
   drawer, Fluent Forms base). Everything here is chrome + motion.
   ================================================================ */

:root{
  --k3-paper:#eae2d2;
  --k3-paper-hi:#f4ead8;
  --k3-ink:#12100c;
  --k3-ink-soft:#1a1613;
  --k3-orange:#d94f1e;
  --k3-hot:#cc3300;
  --k3-green:#3d7a3a;
  --k3-line:rgba(18,16,12,.82);
  --k3-hairline:rgba(18,16,12,.16);
  --k3-mono:"Space Mono",monospace;
  --k3-display:"Archivo Black",Archivo,sans-serif;
  --k3-ease:cubic-bezier(.22,.9,.24,1);
  --k3-shadow:6px 6px 0 var(--k3-ink);
}

html{scroll-behavior:smooth}
body.nhpt3{background:var(--k3-paper)}

/* ---------------- view transitions (MPA) ---------------- */
@view-transition{navigation:auto}
::view-transition-old(root){animation:k3-vt-out .18s var(--k3-ease) both}
::view-transition-new(root){animation:k3-vt-in .26s var(--k3-ease) both}
@keyframes k3-vt-out{to{opacity:0;transform:translateY(-6px)}}
@keyframes k3-vt-in{from{opacity:0;transform:translateY(10px)}}
.k3-header{view-transition-name:k3-header}
.k3-ticker{view-transition-name:k3-ticker}

/* ---------------- paper grain + progress ---------------- */
.k3-grain{position:fixed;inset:0;z-index:3;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.k3-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:120;background:transparent;pointer-events:none}
#k3-progress-bar{display:block;height:100%;width:100%;background:var(--k3-hot);transform-origin:0 50%;transform:scaleX(0)}

/* ---------------- utility bar ---------------- */
.k3-util{display:flex;justify-content:space-between;gap:14px;align-items:center;background:var(--k3-ink);color:var(--k3-paper-hi);font-family:var(--k3-mono);font-size:11px;letter-spacing:.06em;padding:6px 18px;position:relative;z-index:60}
.k3-util a{color:var(--k3-orange);text-decoration:none;border-bottom:1px dashed rgba(217,79,30,.5)}
.k3-util a:hover{border-bottom-style:solid}

/* ---------------- header ---------------- */
.k3-header{position:sticky;top:0;z-index:110;background:color-mix(in srgb,var(--k3-paper) 86%,transparent);
  backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);
  border-bottom:2px solid var(--k3-ink);transition:box-shadow .25s var(--k3-ease)}
.k3-header.is-scrolled{box-shadow:0 4px 0 rgba(18,16,12,.08)}
.k3-nav{display:flex;align-items:center;gap:22px;padding:0 18px;min-height:64px;transition:min-height .25s var(--k3-ease)}
.k3-header.is-scrolled .k3-nav{min-height:52px}
.k3-logo{position:relative;display:flex;align-items:center;background:var(--k3-paper-hi);border:2px solid var(--k3-ink);padding:6px 14px;box-shadow:4px 4px 0 var(--k3-ink);transition:transform .15s var(--k3-ease),box-shadow .15s var(--k3-ease)}
.k3-logo:hover{transform:translate(-1px,-1px);box-shadow:5px 5px 0 var(--k3-ink)}
.k3-logo:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--k3-ink)}
.k3-logo .logo-img{height:34px;width:auto;display:block}
.k3-logo-stamp{position:absolute;right:-10px;top:-10px;background:var(--k3-hot);color:#fff;font-family:var(--k3-mono);font-size:8px;font-weight:700;letter-spacing:.08em;padding:2px 6px;transform:rotate(4deg);opacity:0;transition:opacity .2s,transform .2s}
.k3-logo:hover .k3-logo-stamp{opacity:1;transform:rotate(-2deg)}
.k3-navlinks{display:flex;align-items:center;gap:2px;margin-left:auto;list-style:none;padding:0}
.k3-navlinks>li>a{font-family:var(--k3-mono);font-size:12px;font-weight:700;letter-spacing:.05em;color:var(--k3-ink);text-decoration:none;padding:10px 12px;position:relative}
.k3-navlinks>li>a::after{content:"";position:absolute;left:12px;right:12px;bottom:6px;height:2px;background:var(--k3-hot);transform:scaleX(0);transform-origin:0 50%;transition:transform .22s var(--k3-ease)}
.k3-navlinks>li>a:hover::after,.k3-navlinks>li>a:focus-visible::after{transform:scaleX(1)}
.k3-headmeta{display:flex;align-items:center;gap:8px;font-family:var(--k3-mono);font-size:10px;letter-spacing:.08em;color:var(--k3-ink);opacity:.75;white-space:nowrap}
.k3-feed-dot{width:7px;height:7px;border-radius:50%;background:var(--k3-hot);display:inline-block;animation:k3-blink 1.6s steps(2,jump-none) infinite}
@keyframes k3-blink{50%{opacity:.25}}
.k3-burger{display:none}

/* dropdowns: inherit legacy behaviour, restyle panel */
.k3-navlinks li{position:relative}
.k3-navlinks li ul{border:2px solid var(--k3-ink)!important;box-shadow:var(--k3-shadow)!important;background:var(--k3-paper-hi)!important}
.k3-navlinks li ul a{font-family:var(--k3-mono)!important;font-size:12px!important}
.k3-navlinks li ul a:hover{background:var(--k3-ink)!important;color:var(--k3-paper-hi)!important;padding-left:18px!important;transition:padding-left .15s var(--k3-ease)}

/* ---------------- ticker ---------------- */
.k3-ticker{overflow:hidden;border-bottom:2px solid var(--k3-ink);background:var(--k3-paper-hi);position:relative;z-index:50}
.k3-ticker-track{display:inline-flex;white-space:nowrap;animation:k3-marq 46s linear infinite;will-change:transform}
.k3-ticker:hover .k3-ticker-track{animation-play-state:paused}
@keyframes k3-marq{to{transform:translateX(-50%)}}
.k3-ticker span{font-family:var(--k3-mono)}
.k3-ticker .hot{color:var(--k3-hot);animation:k3-hotpulse 3.4s ease-in-out infinite}
@keyframes k3-hotpulse{50%{opacity:.55}}

/* ---------------- reveal system ---------------- */
[data-r],.k3-reveal-sec{opacity:0;transform:translateY(22px);transition:opacity .7s var(--k3-ease),transform .7s var(--k3-ease)}
[data-r].k3-in,.k3-reveal-sec.k3-in{opacity:1;transform:none}
.k3-stagger>*{opacity:0;transform:translateY(18px);transition:opacity .6s var(--k3-ease),transform .6s var(--k3-ease);transition-delay:calc(var(--si,0)*70ms)}
.k3-stagger.k3-in>*{opacity:1;transform:none}
.k3-hairline{position:relative}
.k3-hairline::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--k3-ink);transform:scaleX(0);transform-origin:0 50%;transition:transform .9s var(--k3-ease) .15s}
.k3-in .k3-hairline::before,.k3-hairline.k3-in::before{transform:scaleX(1)}

/* ---------------- kicker + display type ---------------- */
.k3-kicker{font-family:var(--k3-mono);font-size:12px;font-weight:700;letter-spacing:.14em;color:var(--k3-orange);text-transform:uppercase;margin:0 0 14px}
.k3-h1{font-family:var(--k3-display);text-transform:uppercase;line-height:.92;letter-spacing:-.01em;margin:0 0 22px;color:var(--k3-ink);
  text-shadow:3px 3px 0 rgba(204,51,0,.16)}
.k3-sr{position:absolute;width:1px;height:1px;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* kinetic hero letters */
.k3-kinetic .k3-word{display:inline-block;white-space:nowrap}
.k3-kinetic .k3-ch{display:inline-block;opacity:0;transform:translateY(.6em) rotate(6deg) scaleY(1.4);transform-origin:50% 100%}
.k3-type-go .k3-kinetic .k3-ch{animation:k3-wind .62s var(--k3-ease) forwards;animation-delay:calc(var(--i)*26ms)}
@keyframes k3-wind{60%{opacity:1;transform:translateY(-.06em) rotate(-1.5deg) scaleY(.96)}100%{opacity:1;transform:none}}

/* ---------------- hero ---------------- */
.k3-home .k3-hero{position:relative;padding:64px 0 0;border-bottom:2px solid var(--k3-ink);background:linear-gradient(180deg,var(--k3-paper) 0%,var(--k3-paper-hi) 120%)}
.k3-hero-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,6fr);gap:34px;align-items:center}
.k3-hero-kicker{animation:k3-fadeup .5s var(--k3-ease) both}
.k3-hero .k3-h1{font-size:clamp(54px,8.6vw,132px)}
.k3-hero-copy p:not(.k3-kicker){max-width:46ch}
.k3-hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin:26px 0 18px;animation:k3-fadeup .6s var(--k3-ease) .55s both}
.k3-hero-stage{position:relative;animation:k3-fadeup .8s var(--k3-ease) .25s both}
.k3-hero-stage svg{width:100%;height:auto;display:block}
.k3-hero-baseline{display:flex;gap:0;border-top:2px solid var(--k3-ink);margin-top:46px}
.k3-hero-baseline span{flex:1;text-align:center;font-family:var(--k3-mono);font-size:11px;font-weight:700;letter-spacing:.12em;padding:10px 6px;border-right:1px solid var(--k3-hairline)}
.k3-hero-baseline span:last-child{border-right:0}
@keyframes k3-fadeup{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
[data-k3-parallax-soft]{transform:translateY(calc(var(--k3-scroll,0)*-28px))}

/* ---------------- scroll story ---------------- */
.k3-story{position:relative;height:340vh;background:var(--k3-ink);color:var(--k3-paper-hi)}
.k3-story-sticky{position:sticky;top:0;min-height:100vh;overflow:hidden;display:grid;
  grid-template-columns:minmax(0,4fr) minmax(0,5fr) minmax(0,3fr);gap:28px;align-items:center;padding:72px 4vw 56px}
.k3-story-head h2{font-family:var(--k3-display);font-size:clamp(34px,4.6vw,72px);line-height:.95;margin:0;color:var(--k3-paper-hi);text-shadow:3px 3px 0 rgba(217,79,30,.35)}
.k3-story-stage{background:var(--k3-paper);border:3px solid var(--k3-paper-hi);box-shadow:10px 10px 0 rgba(217,79,30,.9);padding:18px;transform:rotate(calc(-1deg + var(--k3-p,0)*2deg))}
.k3-story-stage svg{width:100%;height:auto;display:block;filter:saturate(calc(.7 + var(--k3-p,0)*.6))}
.k3-story-rail{display:flex;flex-direction:column;gap:18px;position:relative;padding-left:18px}
.k3-stage{opacity:.22;transform:translateX(10px);transition:opacity .4s var(--k3-ease),transform .4s var(--k3-ease);border-left:3px solid transparent;padding-left:14px}
.k3-stage.on{opacity:1;transform:none;border-left-color:var(--k3-orange)}
.k3-stage-n{font-family:var(--k3-mono);font-size:11px;color:var(--k3-orange);letter-spacing:.14em}
.k3-stage h3{font-family:var(--k3-display);font-size:17px;letter-spacing:.02em;margin:4px 0 6px;text-transform:uppercase;color:var(--k3-paper-hi)}
.k3-stage p{font-size:13.5px;line-height:1.55;margin:0;color:rgba(244,234,216,.78)}
.k3-story-ruler{position:absolute;left:0;top:6px;bottom:6px;width:3px;background:rgba(244,234,216,.15)}
.k3-story-ruler::after{content:"";position:absolute;left:0;top:0;width:100%;height:calc(var(--k3-p,0)*100%);background:var(--k3-orange)}
.k3-story-log{position:absolute;left:4vw;bottom:14px;font-family:var(--k3-mono);font-size:10.5px;letter-spacing:.06em;color:rgba(244,234,216,.55);white-space:pre-line;min-height:3em}

/* ---------------- legacy homepage sections re-frame ---------------- */
.k3-reveal-sec{border-bottom:1px solid var(--k3-hairline)}

/* ---------------- floor band ---------------- */
.k3-floor{position:relative;height:52vh;min-height:340px;overflow:hidden;border-top:2px solid var(--k3-ink);border-bottom:2px solid var(--k3-ink)}
.k3-floor img{position:absolute;inset:-12% 0;width:100%;height:124%;object-fit:cover;transform:translateY(calc(var(--k3-vis,0)*-6%));filter:sepia(.22) contrast(1.04)}
.k3-floor-tag{position:absolute;left:18px;bottom:16px;background:var(--k3-ink);color:var(--k3-paper-hi);font-family:var(--k3-mono);font-size:11px;font-weight:700;letter-spacing:.1em;padding:8px 12px;display:flex;align-items:center;gap:8px}

/* ---------------- CTA band ---------------- */
.k3-band{background:var(--k3-orange);border-top:2px solid var(--k3-ink);border-bottom:2px solid var(--k3-ink);overflow:hidden}
.k3-band-in{display:flex;align-items:center;justify-content:space-between;gap:26px;padding:52px 0;flex-wrap:wrap}
.k3-band-title{font-family:var(--k3-display);font-size:clamp(38px,5.4vw,84px);line-height:.9;margin:0;color:var(--k3-ink);text-transform:uppercase}
.k3-band-title em{font-style:normal;color:var(--k3-paper-hi);text-shadow:3px 3px 0 var(--k3-ink)}
.k3-band-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.k3-band-tel{font-family:var(--k3-mono);font-weight:700;color:var(--k3-ink);text-decoration:none;border-bottom:2px dashed var(--k3-ink)}

/* ---------------- buttons ---------------- */
.k3-btn{position:relative;display:inline-flex;align-items:center;gap:10px;font-family:var(--k3-mono);font-weight:700;letter-spacing:.04em;
  background:var(--k3-hot);color:#fff;border:2px solid var(--k3-ink);box-shadow:var(--k3-shadow);padding:13px 20px;text-decoration:none;cursor:pointer;
  transition:transform .15s var(--k3-ease),box-shadow .15s var(--k3-ease)}
.k3-btn:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--k3-ink)}
.k3-btn:active{transform:translate(3px,3px);box-shadow:2px 2px 0 var(--k3-ink)}
.k3-btn-arrow{display:inline-block;transition:transform .18s var(--k3-ease)}
.k3-btn:hover .k3-btn-arrow{transform:translateX(6px)}
.k3-btn-big{font-size:16px;padding:16px 26px}
.k3-btn-ghost{background:var(--k3-paper-hi);color:var(--k3-ink)}
.k3-btn small{display:block;font-size:9px;font-weight:400;letter-spacing:.06em;opacity:.8;margin-top:2px}
.k3-chip{font-family:var(--k3-mono);font-size:11px;font-weight:700;background:var(--k3-paper);border:2px solid var(--k3-ink);padding:8px 12px;cursor:pointer;box-shadow:3px 3px 0 var(--k3-ink);transition:transform .12s,box-shadow .12s}
.k3-chip:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--k3-ink)}
.k3-chip[aria-pressed="true"]{background:var(--k3-ink);color:var(--k3-paper-hi)}

/* ---------------- interior page system ---------------- */
.k3-page{display:block;padding:0 0 46px}
.k3-page.k3-has-rail{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:44px;align-items:start}
.k3-page-content .phero h1{font-family:var(--k3-display);font-size:clamp(38px,5vw,72px);line-height:.94;text-shadow:3px 3px 0 rgba(204,51,0,.14)}
.k3-page-content section.first{border:0}
.k3-page-content h2{position:relative;font-family:var(--k3-display);text-transform:uppercase;letter-spacing:.01em;margin-top:2.2em;padding-top:.55em}
.k3-page-content h2::before{content:"";position:absolute;top:0;left:0;width:64px;height:3px;background:var(--k3-orange)}
.k3-page-content h3{font-family:var(--k3-display);text-transform:uppercase;letter-spacing:.02em}
.k3-page-content p,.k3-page-content li{max-width:70ch;line-height:1.72}
.k3-page-content a:not(.btn):not(.k3-btn){color:var(--k3-hot);text-decoration:none;background-image:linear-gradient(var(--k3-hot),var(--k3-hot));background-size:0% 2px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .25s var(--k3-ease)}
.k3-page-content a:not(.btn):not(.k3-btn):hover{background-size:100% 2px}
.k3-page-content table{border:2px solid var(--k3-ink);border-collapse:collapse;box-shadow:var(--k3-shadow);background:var(--k3-paper-hi);font-family:var(--k3-mono);font-size:14px}
.k3-page-content th{background:var(--k3-ink);color:var(--k3-paper-hi);font-family:var(--k3-mono);text-transform:uppercase;font-size:12px;letter-spacing:.08em;padding:10px 12px}
.k3-page-content td{border:1px solid var(--k3-hairline);padding:9px 12px}
.k3-page-content tr:hover td{background:rgba(217,79,30,.07)}
.k3-page-content blockquote{border:2px solid var(--k3-ink);border-left:8px solid var(--k3-orange);background:var(--k3-paper-hi);box-shadow:var(--k3-shadow);padding:18px 22px;margin:26px 0;font-family:var(--k3-mono)}
.k3-page-content img{border:2px solid var(--k3-ink);box-shadow:var(--k3-shadow)}
.k3-page-content ul li::marker{content:"— ";color:var(--k3-orange)}

/* sticky rail */
.k3-rail{position:sticky;top:96px}
.k3-rail-card{background:var(--k3-paper-hi);border:2px solid var(--k3-ink);box-shadow:var(--k3-shadow);padding:22px;position:relative}
.k3-rail-card::before{content:"";position:absolute;top:-7px;left:18px;width:70px;height:14px;background:rgba(217,79,30,.32);transform:rotate(-2deg)}
.k3-rail-kicker{font-family:var(--k3-mono);font-size:10.5px;font-weight:700;letter-spacing:.12em;color:var(--k3-orange);margin:0 0 10px}
.k3-rail-title{font-family:var(--k3-display);font-size:21px;line-height:1.05;text-transform:uppercase;margin:0 0 14px}
.k3-rail-list{list-style:none;margin:0 0 18px;padding:0;font-family:var(--k3-mono);font-size:12.5px}
.k3-rail-list li{padding:7px 0;border-bottom:1px dashed var(--k3-hairline)}
.k3-rail-list li::before{content:"✓ ";color:var(--k3-green);font-weight:700}
.k3-rail .k3-btn{width:100%;justify-content:center}
.k3-rail-tel{display:block;text-align:center;font-family:var(--k3-mono);font-weight:700;font-size:15px;color:var(--k3-ink);margin:12px 0 6px;text-decoration:none}
.k3-rail-foot{font-family:var(--k3-mono);font-size:9.5px;letter-spacing:.1em;text-align:center;opacity:.55;margin:0}

/* ---------------- quote page: job ticket ---------------- */
.k3-quotepage .k3-page{grid-template-columns:minmax(0,1fr)}
.k3-ticket-shell{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:40px;align-items:start;max-width:1200px;margin:0 auto;padding:0 18px}
.k3-ticket-shell .k3-page{padding:0}
.k3-ticket-readout{position:sticky;top:100px;background:var(--k3-ink);color:var(--k3-paper-hi);border:2px solid var(--k3-ink);box-shadow:8px 8px 0 rgba(217,79,30,.85);padding:20px;font-family:var(--k3-mono)}
.k3-ticket-readout dl{margin:8px 0 0;font-size:12.5px;line-height:1.9;min-height:180px}
.k3-ticket-readout dt{color:rgba(244,234,216,.5);float:left;clear:left;margin-right:8px;text-transform:uppercase;font-size:10.5px;letter-spacing:.1em}
.k3-ticket-readout dt::after{content:":"}
.k3-ticket-readout dd{margin:0;overflow-wrap:anywhere}
.k3-ticket-readout dd:empty::after{content:"—";opacity:.3}
.k3-stamp{margin-top:16px;border:3px double var(--k3-orange);color:var(--k3-orange);text-align:center;font-weight:700;letter-spacing:.2em;padding:10px;transform:rotate(-4deg) scale(0);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.k3-stamp.on{transform:rotate(-4deg) scale(1)}

/* Fluent Forms reskin (loads over legacy + plugin css) */
.nhpt3 .fluentform .ff-el-form-control{background:var(--k3-paper-hi);border:2px solid var(--k3-ink);border-radius:0;font-family:var(--k3-mono);box-shadow:none;transition:box-shadow .15s var(--k3-ease),transform .15s var(--k3-ease)}
.nhpt3 .fluentform .ff-el-form-control:focus{outline:none;box-shadow:4px 4px 0 var(--k3-orange);transform:translate(-1px,-1px);border-color:var(--k3-ink)}
.nhpt3 .fluentform .ff-el-input--label label{font-family:var(--k3-mono);font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.nhpt3 .fluentform .ff-btn-submit{border:2px solid var(--k3-ink)!important;border-radius:0!important;font-family:var(--k3-mono)!important;font-weight:700!important;letter-spacing:.06em!important;box-shadow:var(--k3-shadow)!important;transition:transform .15s,box-shadow .15s!important}
.nhpt3 .fluentform .ff-btn-submit:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--k3-ink)!important}
.nhpt3 .ff-message-success{border:3px double var(--k3-green)!important;background:var(--k3-paper-hi)!important;font-family:var(--k3-mono)!important}

/* ---------------- configurator ---------------- */
.k3-config{background:var(--k3-ink);color:var(--k3-paper-hi);border-top:2px solid var(--k3-ink);padding:58px 0 64px;margin-top:56px}
.k3-config .k3-kicker{color:var(--k3-orange)}
.k3-config-title{font-family:var(--k3-display);font-size:clamp(28px,3.6vw,52px);text-transform:uppercase;margin:0 0 26px;color:var(--k3-paper-hi);text-shadow:3px 3px 0 rgba(217,79,30,.4)}
.k3-config-stage{position:relative;background:var(--k3-paper);border:3px solid var(--k3-paper-hi);box-shadow:10px 10px 0 rgba(217,79,30,.9);min-height:420px;display:flex;align-items:center;justify-content:center;touch-action:pan-y}
.k3-config-stage canvas{display:block;width:100%;height:420px;cursor:grab}
.k3-config-stage canvas:active{cursor:grabbing}
.k3-config-launch small{margin-left:8px}
.k3-config-ui{margin-top:22px}
.k3-config-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;margin-bottom:20px}
.k3-config-row label{font-family:var(--k3-mono);font-size:11px;font-weight:700;letter-spacing:.1em;display:flex;flex-direction:column;gap:8px}
.k3-config-row output{color:var(--k3-orange);font-size:15px}
.k3-config input[type="range"]{accent-color:var(--k3-hot);height:26px}
.k3-config-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.k3-config-note{font-family:var(--k3-mono);font-size:10px;letter-spacing:.1em;opacity:.55;margin-top:14px}

/* ---------------- footer ---------------- */
.k3-seam{height:14px;background:repeating-linear-gradient(90deg,var(--k3-ink) 0 26px,var(--k3-orange) 26px 34px);border-top:2px solid var(--k3-ink);background-size:200% 100%;animation:k3-seam 30s linear infinite}
@keyframes k3-seam{to{background-position:-200% 0}}
.k3-footer{background:var(--k3-ink-soft);color:var(--k3-paper-hi);overflow:hidden;position:relative}
.k3-footer-word{font-family:var(--k3-display);font-size:clamp(64px,12vw,190px);line-height:.85;text-transform:uppercase;color:transparent;-webkit-text-stroke:2px rgba(244,234,216,.16);text-align:center;padding:34px 0 0;user-select:none}
.k3-footer-body{padding:26px 4vw 40px}
.k3-footer-body a{transition:color .15s;position:relative}
.k3-footer-body a:hover{color:var(--k3-orange)!important}

/* ---------------- 404 ---------------- */
.k3-404{display:grid;min-height:100vh;place-items:center;background:var(--k3-paper);text-align:left}
.k3-404-in{max-width:640px;padding:40px 22px;position:relative;z-index:5}
.k3-404 .k3-h1{font-size:clamp(52px,9vw,110px)}
.k3-404-a{color:var(--k3-ink)}
.k3-404-b{color:var(--k3-hot)}
.k3-404-meta{font-family:var(--k3-mono);font-size:13px;margin-top:22px}
.k3-404 .k3-hero-ctas{margin-top:26px}

/* ---------------- drawer touch-ups (legacy markup) ---------------- */
.nhpt3 .drawer{border-left:3px solid var(--k3-ink)!important;box-shadow:-12px 0 0 rgba(217,79,30,.65)!important}
.nhpt3 .scrim.on{backdrop-filter:blur(3px)}

/* ---------------- native WP article fallback ---------------- */
.k3-article-meta{font-family:var(--k3-mono);font-size:12px;letter-spacing:.08em;opacity:.65}

/* ---------------- motion preferences ---------------- */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  [data-r],.k3-reveal-sec,.k3-stagger>*{opacity:1!important;transform:none!important;transition:none!important}
  .k3-kinetic .k3-ch{opacity:1!important;transform:none!important;animation:none!important}
  .k3-ticker-track{animation:none!important}
  .k3-seam{animation:none!important}
  ::view-transition-old(root),::view-transition-new(root){animation:none!important}
  .k3-story{height:auto}
  .k3-story-sticky{position:static;min-height:0}
  .k3-stage{opacity:1;transform:none}
  [data-k3-parallax-soft]{transform:none}
  .k3-floor img{transform:none}
}

/* ---------------- responsive ---------------- */
@media (max-width:1080px){
  .k3-page.k3-has-rail{grid-template-columns:minmax(0,1fr)}
  .k3-rail{position:static;max-width:420px}
  .k3-ticket-shell{grid-template-columns:minmax(0,1fr)}
  .k3-ticket-readout{position:static}
  .k3-story-sticky{grid-template-columns:1fr;gap:18px;padding:56px 5vw;align-content:center}
  .k3-story-head h2{font-size:clamp(30px,7vw,54px)}
  .k3-story-log{display:none}
}
@media (max-width:900px){
  .k3-hero-grid{grid-template-columns:1fr}
  .k3-hero-stage{max-width:560px}
  .k3-navlinks{display:none;position:absolute;top:100%;left:0;right:0;background:var(--k3-paper-hi);border-bottom:2px solid var(--k3-ink);flex-direction:column;align-items:stretch;padding:8px 0 14px;max-height:calc(100vh - 120px);overflow:auto}
  .k3-navlinks.open{display:flex}
  .k3-navlinks>li>a{display:block;padding:12px 20px;font-size:14px}
  .k3-headmeta{display:none}
  .k3-burger{display:flex;flex-direction:column;gap:4px;margin-left:auto;background:var(--k3-paper-hi);border:2px solid var(--k3-ink);box-shadow:3px 3px 0 var(--k3-ink);padding:10px;cursor:pointer}
  .k3-burger span{display:block;width:20px;height:2.5px;background:var(--k3-ink);transition:transform .2s var(--k3-ease),opacity .2s}
  .k3-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .k3-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .k3-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
  .k3-config-row{grid-template-columns:1fr}
  .k3-band-in{justify-content:center;text-align:center}
  .k3-util{font-size:10px;flex-wrap:wrap;justify-content:center}
  .k3-footer-word{font-size:clamp(48px,14vw,90px)}
  .k3-hero .k3-h1{font-size:clamp(44px,11.5vw,80px)}
}

/* ---------------- print (job ticket prints clean) ---------------- */
@media print{
  .k3-grain,.k3-ticker,.k3-seam,.k3-footer-word,#nhpt-sticky-cta,.k3-band,.k3-config{display:none!important}
  .k3-header{position:static;box-shadow:none}
  body.nhpt3{background:#fff}
}
