/* ── SHARED STYLES — Justsen Pacific ─────────────────────────── */
:root {
  --flame:  #E8401C;
  --ember:  #C43010;
  --amber:  #E8A020;
  --gold:   #F5C842;
  --green:  #3A7A42;
  --cream:  #F5EFE0;
  --muted:  rgba(245,239,224,0.55);
  --dark:   #0F0E0C;
  --panel:  #161410;
  --border: rgba(232,64,28,0.15);
  --bdr2:   rgba(245,239,224,0.08);
  --fd: 'Playfair Display', Georgia, serif;
  --fb: 'DM Sans', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--dark);color:var(--cream);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
p+p{margin-top:16px}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:76px;display:flex;align-items:center;justify-content:space-between;padding:0 52px;transition:background .4s,box-shadow .4s}
nav.scrolled{background:rgba(15,14,12,.97);box-shadow:0 1px 0 var(--bdr2);backdrop-filter:blur(12px)}
.nav-logo img{height:38px;width:auto}
.nav-links{display:flex;gap:34px;list-style:none}
.nav-links a{font-size:13px;font-weight:500;color:rgba(245,239,224,.65);letter-spacing:.4px;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--cream)}
.nav-links a.active{border-bottom:1px solid var(--flame);padding-bottom:2px}
.nav-cta{background:var(--flame);color:#fff;font-size:13px;font-weight:600;padding:10px 24px;border-radius:3px;transition:background .2s,transform .15s}
.nav-cta:hover{background:#f0521f;transform:translateY(-1px)}

/* PAGE HERO */
.page-hero{position:relative;min-height:72vh;display:flex;align-items:flex-end;padding:0 52px 80px;overflow:hidden;margin-top:0}
.ph-bg{position:absolute;inset:0;background:center/cover no-repeat;background-color:#0f0e0c}
.ph-ov{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,8,6,.9) 0%,rgba(10,8,6,.65) 50%,rgba(10,8,6,.25) 100%),linear-gradient(to top,rgba(10,8,6,.7) 0%,transparent 50%)}
.ph-content{position:relative;z-index:2;max-width:680px}
.ph-h1{font-family:var(--fd);font-size:clamp(40px,5.5vw,68px);font-weight:700;line-height:1.06;letter-spacing:-1.5px;color:var(--cream);margin-bottom:20px}
.ph-h1 em{font-style:italic;color:var(--amber);font-weight:400}
.ph-sub{font-size:16px;font-weight:300;color:var(--muted);line-height:1.75;max-width:520px}

/* STATS STRIP */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--bdr2)}
.sc{padding:36px 44px;border-right:1px solid var(--bdr2);position:relative;transition:background .3s}
.sc:last-child{border-right:none}
.sc:hover{background:rgba(232,64,28,.04)}
.sc::after{content:'';position:absolute;top:0;left:0;height:2px;width:0;background:var(--flame);transition:width .4s ease}
.sc:hover::after{width:100%}
.sn{font-family:var(--fd);font-size:44px;font-weight:700;color:var(--flame);line-height:1;letter-spacing:-1.5px;margin-bottom:8px}
.sl{font-size:12px;font-weight:400;color:var(--muted);line-height:1.5}

/* SECTIONS */
.sec{padding:96px 52px}
.stag{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--flame);margin-bottom:18px}
.stag::before{content:'';display:block;width:22px;height:1.5px;background:var(--flame)}
h2.sh{font-family:var(--fd);font-size:clamp(32px,4vw,52px);font-weight:700;line-height:1.08;letter-spacing:-1.2px;color:var(--cream);margin-bottom:20px}
h2.sh em{font-style:italic;color:var(--amber);font-weight:400}
.lead{font-size:16px;font-weight:300;color:var(--muted);line-height:1.8;max-width:560px}

/* BUTTONS */
.btn-f{background:var(--flame);color:#fff;font-size:14px;font-weight:600;padding:15px 30px;border-radius:3px;display:inline-flex;align-items:center;gap:8px;transition:background .2s,transform .15s}
.btn-f:hover{background:#f0521f;transform:translateY(-2px)}
.btn-g{border:1px solid rgba(245,239,224,.22);color:var(--cream);font-size:14px;font-weight:400;padding:15px 30px;border-radius:3px;transition:border-color .2s}
.btn-g:hover{border-color:var(--cream)}

/* PHOTO BAND */
.pb{position:relative;height:500px;display:flex;align-items:center;overflow:hidden}
.pb-bg{position:absolute;inset:0;background:center/cover no-repeat;background-color:#0f0e0c}
.pb-ov{position:absolute;inset:0;background:linear-gradient(to right,rgba(15,14,12,.92) 0%,rgba(15,14,12,.6) 45%,rgba(15,14,12,.1) 100%)}
.pb-ct{position:relative;z-index:2;padding:0 52px;max-width:640px}

/* SOLUTIONS PAGE — output grid */
.out-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:56px;background:var(--bdr2);min-width:0}
.out-card{background:var(--panel);padding:40px 32px;transition:background .3s}
.out-card:hover{background:#1a1712}
.out-icon{font-size:32px;margin-bottom:20px;display:block}
.out-card h3{font-family:var(--fd);font-size:20px;font-weight:700;color:var(--cream);margin-bottom:12px}
.out-card p{font-size:13px;color:var(--muted);line-height:1.75}

/* SOLUTIONS PAGE — steps */
.steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr auto 1fr;gap:0;align-items:start;margin-top:60px}
.step{padding:32px 24px;background:rgba(232,64,28,.05);border:1px solid var(--border)}
.step-n{font-family:var(--fd);font-size:36px;font-weight:700;color:rgba(232,64,28,.2);line-height:1;margin-bottom:14px}
.step h4{font-family:var(--fd);font-size:16px;font-weight:700;color:var(--cream);margin-bottom:10px}
.step p{font-size:12px;color:var(--muted);line-height:1.7}
.step-arrow{padding:32px 12px;font-size:20px;color:rgba(232,64,28,.35);align-self:center}

/* SOLUTIONS PAGE — industry grid */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:56px;background:var(--bdr2)}
.ind-card{background:var(--panel);padding:36px 32px;transition:background .3s}
.ind-card:hover{background:#1a1712}
.ind-ico{font-size:28px;margin-bottom:16px;display:block}
.ind-card h4{font-family:var(--fd);font-size:17px;font-weight:700;color:var(--cream);margin-bottom:10px}
.ind-card p{font-size:13px;color:var(--muted);line-height:1.7}

/* MATERIALS PAGE — full material cards */
.mat-full-grid{display:flex;flex-direction:column;gap:1px;margin-top:56px}
.mat-full-card{display:grid;grid-template-columns:420px 1fr;background:var(--bdr2)}
.mat-full-card:nth-child(even){grid-template-columns:1fr 420px}
.mat-full-card:nth-child(even) .mfc-img{order:2}
.mat-full-card:nth-child(even) .mfc-body{order:1}
.mfc-img{background:center/cover no-repeat;min-height:360px;background-color:#1a1208}
.mfc-body{background:var(--panel);padding:52px 48px}
.mat-tag-lg{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--flame);font-weight:600;margin-bottom:12px}
.mfc-body h3{font-family:var(--fd);font-size:28px;font-weight:700;color:var(--cream);margin-bottom:18px;line-height:1.2}
.mfc-body p{font-size:14px;color:var(--muted);line-height:1.8}
.mfc-specs{margin-top:28px;border-top:1px solid var(--bdr2);padding-top:20px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.spec{}
.spec-l{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--flame);font-weight:600;margin-bottom:3px}
.spec-v{font-size:13px;color:var(--cream);font-weight:500}

/* MATERIALS PAGE — certification */
.cert-2col{display:grid;grid-template-columns:1fr 1fr;gap:56px;margin-top:48px}
.cert-badges{display:flex;flex-direction:column;gap:16px}
.cert-badge-lg{padding:24px;background:rgba(232,64,28,.06);border:1px solid var(--border);border-radius:3px}
.cb-icon{font-size:20px;margin-bottom:10px}
.cert-badge-lg h4{font-family:var(--fd);font-size:16px;font-weight:700;color:var(--cream);margin-bottom:8px}
.cert-badge-lg p{font-size:13px;color:var(--muted);line-height:1.65}

/* MATERIALS PAGE — state list */
.state-list{margin-top:28px;display:flex;flex-direction:column;gap:14px}
.state-item{display:flex;align-items:flex-start;gap:14px}
.si-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);flex-shrink:0;margin-top:5px}
.state-item.featured .si-dot{background:var(--flame)}
.state-item strong{font-size:14px;font-weight:600;color:var(--cream);display:block;margin-bottom:2px}
.state-item span{font-size:13px;color:var(--muted);line-height:1.6}

/* MATERIALS PAGE — who we supply */
.who-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr2)}
.who-card{background:var(--panel);padding:36px 28px;transition:background .3s}
.who-card:hover{background:#1a1712}
.who-ico{font-size:26px;margin-bottom:14px;display:block}
.who-card h4{font-family:var(--fd);font-size:16px;font-weight:700;color:var(--cream);margin-bottom:8px}
.who-card p{font-size:13px;color:var(--muted);line-height:1.7}

/* CASE STUDIES PAGE */
.cs-section{}
.cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.cs-grid.reverse{direction:rtl}
.cs-grid.reverse>*{direction:ltr}
.cs-img{overflow:hidden;max-height:560px}
.cs-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.cs-img:hover img{transform:scale(1.03)}
.cs-body{padding:64px 56px;display:flex;flex-direction:column;justify-content:center}
.cs-location{font-size:13px;color:var(--amber);margin-bottom:20px;margin-top:-8px}
.cs-body p{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:0}
.cs-body p+p{margin-top:14px}
.cs-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:36px;border-top:1px solid var(--bdr2);padding-top:28px}
.csm{padding-right:20px}
.csm-v{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--flame);line-height:1}
.csm-l{font-size:11px;color:var(--muted);margin-top:4px}
.cs-quote{margin-top:28px;padding:20px 24px;background:rgba(232,64,28,.06);border-left:3px solid var(--flame)}
.cs-quote{font-family:var(--fd);font-size:15px;font-style:italic;color:var(--cream);line-height:1.7}
.cs-quote cite{display:block;font-size:12px;font-style:normal;color:var(--amber);margin-top:12px;font-weight:600}

/* COMPANY PAGE */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.timeline{margin-top:56px;position:relative;padding-left:32px}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background:var(--border)}
.tl-item{position:relative;padding-bottom:40px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:'';position:absolute;left:-36px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--flame)}
.tl-year{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--flame);margin-bottom:6px}
.tl-item h4{font-family:var(--fd);font-size:18px;font-weight:700;color:var(--cream);margin-bottom:8px}
.tl-item p{font-size:13px;color:var(--muted);line-height:1.75}
.val-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:56px;background:var(--bdr2)}
.val-card{background:var(--panel);padding:40px 36px;transition:background .3s;position:relative;overflow:hidden}
.val-card:hover{background:#1a1712}
.val-ico{font-size:28px;margin-bottom:18px;display:block}
.val-card h4{font-family:var(--fd);font-size:18px;font-weight:700;color:var(--cream);margin-bottom:10px}
.val-card p{font-size:13px;color:var(--muted);line-height:1.75}

/* TESTIMONIAL */
.testi{background:var(--panel);padding:100px 52px;text-align:center;border-top:1px solid var(--bdr2);border-bottom:1px solid var(--bdr2)}
.tq{font-family:var(--fd);font-size:clamp(20px,2.6vw,30px);font-style:italic;font-weight:400;color:var(--cream);line-height:1.55;max-width:800px;margin:0 auto 32px;position:relative}
.tq::before{content:'\201C';display:block;font-size:96px;line-height:.75;color:var(--flame);opacity:.3;margin-bottom:16px}
.tn{font-size:14px;font-weight:600;color:var(--amber)}
.tc{font-size:12px;color:var(--muted);margin-top:5px}

/* CTA BAND */
.cta{background:var(--dark);padding:112px 52px;display:grid;grid-template-columns:1fr auto;gap:60px;align-items:center}
.cta h2{font-family:var(--fd);font-size:clamp(30px,4vw,52px);font-weight:700;letter-spacing:-1px;line-height:1.08;color:var(--cream)}
.cta h2 em{font-style:italic;color:var(--flame);font-weight:400}
.cta>div>p{font-size:15px;color:var(--muted);line-height:1.75;margin-top:16px;max-width:500px}
.cta-b{display:flex;flex-direction:column;gap:12px}

/* CONTACT PAGE */
.contact-page{display:grid;grid-template-columns:1fr 1.3fr;min-height:calc(100vh - 76px);margin-top:76px}
.contact-info{padding:80px 52px;background:var(--panel);border-right:1px solid var(--bdr2)}
.ci-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px}
.ci-icon{width:40px;height:40px;background:rgba(232,64,28,.1);border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.ci-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--flame);font-weight:600;margin-bottom:3px}
.ci-value{font-size:14px;color:var(--cream);font-weight:500}
.ci-value a{transition:color .2s}
.ci-value a:hover{color:var(--flame)}
.contact-note{margin-top:36px;padding:24px;background:rgba(232,64,28,.05);border:1px solid var(--border)}
.contact-note h4{font-family:var(--fd);font-size:15px;font-weight:700;color:var(--cream);margin-bottom:14px}
.contact-note ul{list-style:none}
.contact-note li{font-size:13px;color:var(--muted);padding:6px 0;border-bottom:1px solid var(--bdr2);padding-left:12px;position:relative}
.contact-note li::before{content:'→';position:absolute;left:0;color:var(--flame)}
.contact-note li:last-child{border-bottom:none}
.contact-form-wrap{padding:80px 52px;background:var(--dark);overflow-y:auto}
.contact-form{max-width:600px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:12px;font-weight:600;color:rgba(245,239,224,.6);letter-spacing:.5px;margin-bottom:7px;text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;background:rgba(245,239,224,.05);border:1px solid var(--bdr2);border-radius:3px;font-family:var(--fb);font-size:14px;color:var(--cream);transition:border-color .2s;-webkit-appearance:none}
.form-group input:focus,.form-group select,.form-group textarea:focus{outline:none;border-color:var(--flame)}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(245,239,224,.25)}
.form-group select{color:var(--cream);background-color:#161410}
.form-group select option{background:#161410}
.form-group textarea{resize:vertical;min-height:120px}

/* FOOTER */
footer{background:#080806;border-top:1px solid var(--bdr2);padding:72px 52px 40px}
.ft{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:52px;padding-bottom:52px;border-bottom:1px solid var(--bdr2);margin-bottom:32px}
.fb img{height:32px;margin-bottom:18px}
.fb p{font-size:13px;color:var(--muted);line-height:1.75;max-width:250px}
.fc h5{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--flame);margin-bottom:18px}
.fc ul{list-style:none}
.fc li{margin-bottom:11px}
.fc a{font-size:13px;color:var(--muted);transition:color .2s}
.fc a:hover{color:var(--cream)}
.fb2{display:flex;justify-content:space-between;align-items:center}
.fcp{font-size:12px;color:rgba(245,239,224,.25)}
.fcs{display:flex;gap:12px}
.chip{font-size:11px;font-weight:600;padding:4px 12px;border-radius:2px;border:1px solid rgba(232,64,28,.2);color:rgba(232,64,28,.6)}

/* REVEAL */
.r{opacity:1;transform:translateY(0);transition:opacity .75s ease,transform .75s ease}
.r.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* RESPONSIVE */
@media(max-width:1024px){
  .out-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr;gap:12px}
  .step-arrow{display:none}
  .mat-full-card,.mat-full-card:nth-child(even){grid-template-columns:1fr;direction:ltr}
  .mfc-img{min-height:260px}
  .cs-grid,.cs-grid.reverse{grid-template-columns:1fr;direction:ltr}
  .cs-body{padding:40px 32px}
  .cs-metrics{grid-template-columns:repeat(2,1fr)}
  .cert-2col,.two-col{grid-template-columns:1fr}
  .contact-page{grid-template-columns:1fr}
  .who-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  nav{padding:0 24px}
  .nav-links{display:none}
  .page-hero,.sec,.pb-ct,.cta{padding-left:24px;padding-right:24px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .ind-grid,.val-grid{grid-template-columns:1fr}
  .cta{grid-template-columns:1fr}
  .ft{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
}
