/* ===========================================================
   PanSys Technologies — premium, confident, glassy
   Type: Satoshi (Fontshare). Palette: deep emerald + lime + glass.
   =========================================================== */
:root{
  --ink:#0a130f;            /* near-black, green-black */
  --pine:#0a2c20;           /* deep emerald section */
  --pine-2:#0d3a2a;
  --pine-3:#0c3326;
  --emerald:#127a55;        /* brand green */
  --lime:#aef03f;           /* vibrant accent (approved family) */
  --lime-2:#c2ff5e;
  --bone:#f5f8f3;           /* warm light base */
  --bone-2:#eaf0e8;
  --paper:#ffffff;
  --glass:rgba(255,255,255,.72);
  --glass-line:rgba(10,19,15,.10);
  --line:rgba(10,19,15,.10);
  --line-d:rgba(255,255,255,.14);
  --fg:#0a130f;
  --fg-2:#56655d;
  --fg-light:#eef6f0;
  --fg-light-2:#9fbfae;
  --sans:"Satoshi",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --shell:1180px;
  --r:20px;
  --shadow:0 30px 70px -40px rgba(10,19,15,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bone);color:var(--fg);-webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden;font-weight:500}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--lime);color:var(--ink)}
.shell{width:100%;max-width:var(--shell);margin:0 auto;padding:0 26px}
.skip{position:absolute;left:-9999px}
.skip:focus{left:16px;top:16px;background:var(--ink);color:#fff;padding:10px 14px;border-radius:8px;z-index:200}

/* ---- type ---- */
.h-sec{font-weight:800;font-size:clamp(32px,4.8vw,60px);line-height:1.0;letter-spacing:-0.035em;color:var(--fg);max-width:17ch}
.h-sec.light{color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--emerald);margin-bottom:18px}
.eyebrow.on-light{color:var(--emerald)}
.panel-sec .eyebrow,.process .eyebrow,.quote .eyebrow{color:var(--lime)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 4px rgba(174,240,63,.2)}
.head{margin-bottom:54px;max-width:780px}
.head-sub{margin-top:18px;color:var(--fg-2);font-size:18px;font-weight:500;max-width:58ch}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:15px;padding:14px 24px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:transform .18s,background .18s,color .18s,box-shadow .18s;white-space:nowrap}
.btn-lg{padding:17px 30px;font-size:16px}
.btn-block{width:100%;justify-content:center}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(4px)}
.btn-accent{background:var(--lime);color:var(--ink);box-shadow:0 16px 34px -16px rgba(174,240,63,.85)}
.btn-accent:hover{background:var(--lime-2);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.28);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(255,255,255,.16);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#142019}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:100;background:rgba(245,248,243,.72);backdrop-filter:saturate(180%) blur(18px);border-bottom:1px solid var(--line);transition:box-shadow .3s ease,background .3s ease}
.nav.scrolled{background:rgba(245,248,243,.93);box-shadow:0 14px 36px -22px rgba(10,19,15,.5)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:18px}
.brand{display:inline-flex;align-items:center;gap:11px;color:var(--ink)}
.brand-mark{flex:none}
.brand-name{font-weight:800;font-size:19px;letter-spacing:-0.03em}
.brand-tm{color:var(--fg-2);font-weight:600}
.nav-links{display:flex;gap:30px}
.nav-links a{font-size:14.5px;font-weight:600;color:var(--fg);opacity:.78;transition:opacity .15s}
.nav-links a:hover{opacity:1}
.nav-cta{padding:11px 20px;font-size:14px}

/* ---- hero ---- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--ink)}
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%;opacity:0;transform:scale(1.05);transition:opacity 1.5s ease;will-change:opacity,transform}
.hero-slide.is-active{opacity:1;animation:kenburns 8s ease-out both}
.hero-slide--farm{object-position:24% 50%}
@keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.14)}}
@media (prefers-reduced-motion:reduce){.hero-slide{transition:none}.hero-slide.is-active{animation:none}}
.hero-scrim{position:absolute;inset:0;background:
  linear-gradient(100deg,rgba(8,20,15,.92) 0%,rgba(8,20,15,.64) 42%,rgba(8,28,20,.16) 74%,rgba(10,44,32,.4) 100%),
  radial-gradient(60% 60% at 88% 12%,rgba(174,240,63,.16),transparent 70%),
  linear-gradient(0deg,rgba(8,20,15,.72),transparent 42%)}
.hero-inner{position:relative;z-index:1;padding:120px 26px}
.hero h1{font-weight:900;font-size:clamp(42px,6.8vw,86px);line-height:.97;letter-spacing:-0.04em;max-width:15ch}
.hero h1 .accent{color:var(--lime)}
.hero-sub{margin-top:26px;max-width:52ch;font-size:clamp(16px,1.6vw,19px);font-weight:500;color:#dcebe1;line-height:1.6}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.hero-stats{display:flex;gap:14px;margin-top:54px;flex-wrap:wrap}
.hero-stats>div{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(10px);border-radius:16px;padding:16px 22px}
.hero-stats strong{display:block;font-weight:800;font-size:28px;letter-spacing:-0.03em;color:#fff}
.hero-stats span{font-size:13px;color:var(--fg-light-2);font-weight:600}
.hero-dots{position:absolute;z-index:2;right:30px;bottom:30px;display:flex;gap:9px}
.hero-dot{width:30px;height:5px;border-radius:999px;border:none;cursor:pointer;background:rgba(255,255,255,.32);padding:0;transition:background .25s,width .25s}
.hero-dot:hover{background:rgba(255,255,255,.6)}
.hero-dot.is-on{background:var(--lime);width:48px}

/* ---- trust ---- */
.trust{background:var(--ink);color:var(--fg-light);border-top:1px solid var(--line-d)}
.trust-inner{padding:28px 26px;text-align:center}
.trust-inner p{font-size:clamp(15px,1.8vw,18px);font-weight:500;color:#c4dccf;max-width:72ch;margin:0 auto}
.trust-inner strong{color:var(--lime);font-weight:700}

/* ---- sections ---- */
.section{padding:clamp(72px,9vw,120px) 0}
.numbers{background:var(--bone)}
.num-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.num-card{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:32px 26px;overflow:hidden;transition:transform .22s,box-shadow .22s}
.num-card::before{content:"";position:absolute;left:0;top:0;width:100%;height:4px;background:linear-gradient(90deg,var(--lime),var(--emerald))}
.num-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.num-card .num{font-weight:800;font-size:36px;letter-spacing:-0.03em;color:var(--ink);margin-bottom:10px;line-height:1}
.num-card p{color:var(--fg-2);font-size:15px;font-weight:500}

/* ---- systems ---- */
.systems{background:linear-gradient(180deg,var(--bone) 0%,var(--bone-2) 100%)}
.sys-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.sys-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .22s,box-shadow .22s}
.sys-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.sys-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.sys-media img{width:100%;height:100%;object-fit:cover;transition:transform .55s}
.sys-card:hover .sys-media img{transform:scale(1.06)}
.sys-media::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,20,15,.5),transparent 45%)}
.sys-tag{position:absolute;top:14px;left:14px;z-index:1;font-size:12px;font-weight:800;color:var(--ink);background:var(--lime);padding:6px 11px;border-radius:9px;letter-spacing:.02em}
.sys-body{padding:26px 26px 30px}
.sys-body h3{font-weight:800;font-size:23px;letter-spacing:-0.02em;margin-bottom:10px}
.sys-body>p{color:var(--fg-2);font-size:15px;font-weight:500;margin-bottom:16px}
.ticks{list-style:none;display:flex;flex-direction:column;gap:9px}
.ticks li{position:relative;padding-left:26px;font-size:14.5px;font-weight:500;color:var(--fg)}
.ticks li::before{content:"";position:absolute;left:0;top:6px;width:13px;height:8px;border-left:2.5px solid var(--emerald);border-bottom:2.5px solid var(--emerald);transform:rotate(-45deg)}

/* ---- panel section (deep) ---- */
.panel-sec{position:relative;background:var(--pine);color:var(--fg-light);overflow:hidden}
.panel-sec::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 60% at 80% 0%,rgba(174,240,63,.12),transparent 70%);pointer-events:none}
.panel-grid{position:relative;display:grid;grid-template-columns:0.82fr 1fr;gap:60px;align-items:center}
.panel-media{border-radius:var(--r);overflow:hidden;border:1px solid var(--line-d);background:#fff;box-shadow:var(--shadow)}
.panel-media img{width:100%;max-height:560px;object-fit:contain;padding:14px;background:#fff}
.panel-copy p{color:#c4dccf;font-weight:500;margin-top:16px;max-width:54ch}
.panel-specs{margin-top:30px;display:flex;flex-direction:column;gap:0}
.panel-specs div{display:flex;align-items:baseline;gap:16px;font-size:15px;font-weight:500;color:#dcebe1;border-top:1px solid var(--line-d);padding:15px 0}
.panel-specs .mono{color:var(--lime);font-size:17px;font-weight:800;letter-spacing:-0.02em;flex:none;min-width:70px}

/* ---- comparison ---- */
.compare{background:var(--bone)}
.table-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--line);background:var(--paper);box-shadow:var(--shadow)}
.ctable{width:100%;border-collapse:collapse;min-width:640px}
.ctable th,.ctable td{padding:18px 22px;text-align:left;font-size:15px;border-bottom:1px solid var(--line)}
.ctable thead th{font-size:12px;letter-spacing:.07em;text-transform:uppercase;color:var(--fg-2);font-weight:700;background:var(--bone-2)}
.ctable td:first-child{color:var(--fg-2);font-weight:600}
.ctable .hl{background:rgba(18,122,85,.07)}
.ctable thead .hl{color:#0a130f;background:var(--lime)}
.ctable td.hl{font-weight:800;color:var(--ink)}
.ctable tbody tr:last-child td{border-bottom:none}

/* ---- built for ---- */
.builtfor{background:linear-gradient(180deg,var(--bone-2),var(--bone))}
.bf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.bf{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:26px;transition:transform .2s,box-shadow .2s}
.bf:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.bf h4{font-weight:800;font-size:18px;margin-bottom:8px;letter-spacing:-0.01em}
.bf h4::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--lime);margin-right:9px;vertical-align:middle}
.bf p{color:var(--fg-2);font-size:14.5px;font-weight:500}

/* ---- process (deep) ---- */
.process{position:relative;background:var(--ink);color:var(--fg-light);overflow:hidden}
.process::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 70% at 10% 0%,rgba(18,122,85,.22),transparent 65%);pointer-events:none}
.steps{position:relative;list-style:none;display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.steps li{border-top:2px solid rgba(174,240,63,.4);padding-top:20px}
.steps .step-n{font-size:13px;color:var(--lime);font-weight:800;letter-spacing:.05em}
.steps h4{font-weight:800;font-size:20px;margin:12px 0 8px;letter-spacing:-0.01em}
.steps p{color:#b3ccbe;font-size:14px;font-weight:500}

/* ---- projects ---- */
.projects{background:var(--bone)}
.proj-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:20px}
.proj{position:relative;border-radius:var(--r);overflow:hidden;min-height:360px;border:1px solid var(--line);box-shadow:var(--shadow)}
.proj img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s}
.proj:hover img{transform:scale(1.06)}
.proj figcaption{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;gap:5px;padding:26px;color:#fff;background:linear-gradient(0deg,rgba(6,16,12,.92) 0%,rgba(6,16,12,.3) 52%,transparent 100%)}
.proj-kind{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--lime)}
.proj figcaption strong{font-weight:800;font-size:22px;letter-spacing:-0.02em}
.proj figcaption span:last-child{font-size:13.5px;color:#d6e4db;font-weight:500}

/* ---- quote (deep) ---- */
.quote{position:relative;background:var(--pine-2);color:var(--fg-light);overflow:hidden}
.quote::before{content:"";position:absolute;inset:0;background:radial-gradient(45% 60% at 90% 100%,rgba(174,240,63,.14),transparent 70%);pointer-events:none}
.quote-grid{position:relative;display:grid;grid-template-columns:0.9fr 1.1fr;gap:56px;align-items:start}
.quote-copy p{color:#c4dccf;font-weight:500;margin-top:16px;max-width:46ch}
.quote-points{list-style:none;margin-top:24px;display:flex;flex-direction:column;gap:11px}
.quote-points li{position:relative;padding-left:26px;color:#e6f1ea;font-size:15px;font-weight:500}
.quote-points li::before{content:"";position:absolute;left:0;top:6px;width:13px;height:8px;border-left:2.5px solid var(--lime);border-bottom:2.5px solid var(--lime);transform:rotate(-45deg)}
.quote-form{background:var(--paper);border-radius:var(--r);padding:32px;color:var(--fg);box-shadow:var(--shadow)}
.quote-form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.quote-form label{display:flex;flex-direction:column;gap:7px;font-size:12.5px;font-weight:700;color:var(--fg-2);margin-bottom:16px;letter-spacing:.02em;text-transform:uppercase}
.quote-form input,.quote-form select,.quote-form textarea{font-family:var(--sans);font-size:15px;font-weight:500;text-transform:none;letter-spacing:normal;color:var(--ink);background:var(--bone);border:1px solid var(--line);border-radius:12px;padding:14px 15px;outline:none;transition:border .15s,box-shadow .15s}
.quote-form input:focus,.quote-form select:focus,.quote-form textarea:focus{border-color:var(--emerald);box-shadow:0 0 0 3px rgba(18,122,85,.14)}
.quote-form textarea{resize:vertical}
.form-note{margin-top:14px;font-size:14px;text-transform:none;letter-spacing:normal;font-weight:600;text-align:center}
.form-note.ok{color:#127a55}
.form-note.err{color:#c0392b}

/* ---- faq ---- */
.faq{background:var(--bone)}
.faq-list{max-width:840px}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{list-style:none;cursor:pointer;padding:20px 0;font-weight:700;font-size:18px;letter-spacing:-0.01em;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-weight:500;font-size:26px;color:var(--emerald);transition:transform .2s;flex:none;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 0 22px;color:var(--fg-2);font-size:15.5px;font-weight:500;max-width:70ch}

/* ---- cta strip ---- */
.cta-strip{position:relative;background:var(--lime);color:var(--ink);overflow:hidden}
.cta-strip::before{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;background:rgba(10,19,15,.06)}
.cta-inner{position:relative;padding:clamp(58px,7vw,92px) 26px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.cta-inner h2{font-weight:900;font-size:clamp(32px,4.6vw,54px);letter-spacing:-0.04em}
.cta-inner p{font-size:18px;font-weight:500;color:rgba(10,19,15,.72)}
.cta-inner .btn-accent{background:var(--ink);color:#fff;box-shadow:none}
.cta-inner .btn-accent:hover{background:#142019}

/* ---- footer ---- */
.footer{background:var(--ink);color:var(--fg-light-2)}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:42px;padding:66px 26px 36px}
.footer .brand{color:#fff}
.footer-tag{margin-top:16px;font-size:14.5px;font-weight:500;color:var(--fg-light-2);max-width:38ch}
.footer-links{display:flex;flex-direction:column;gap:11px}
.footer-links a{font-size:14.5px;font-weight:500;color:#cfe0d6;transition:color .15s}
.footer-links a:hover{color:var(--lime)}
.footer-contact{display:flex;flex-direction:column;gap:8px;font-size:14.5px;font-weight:500}
.footer-contact a:hover{color:var(--lime)}
.footer-base{display:flex;justify-content:space-between;gap:16px;padding:22px 26px;border-top:1px solid var(--line-d);font-size:13px;color:#7c948a;flex-wrap:wrap;font-weight:500}

/* ---- top utility bar ---- */
.topbar{background:var(--ink);color:var(--fg-light-2);border-bottom:1px solid var(--line-d)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:38px;gap:16px;font-size:12.5px}
.topbar-tag{display:inline-flex;align-items:center;gap:8px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--lime);font-size:11px}
.topbar-dot{width:6px;height:6px;border-radius:50%;background:var(--lime)}
.topbar-meta{display:flex;align-items:center;gap:14px;color:#bcd0c4;font-weight:500}
.topbar-meta a:hover{color:var(--lime)}
.topbar-sep{width:1px;height:13px;background:rgba(255,255,255,.22)}

/* ---- feature band (cinematic) ---- */
.feature-band{position:relative;overflow:hidden;color:#fff;display:flex;align-items:center;min-height:clamp(380px,52vw,560px)}
.feature-band>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 56%;z-index:0;transform:scale(1.16);will-change:transform}
@keyframes glowdrift{0%,100%{background-position:0% 0%}50%{background-position:100% 65%}}
.panel-sec::before,.process::before,.quote::before{background-size:190% 190%;animation:glowdrift 17s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){.panel-sec::before,.process::before,.quote::before{animation:none}}
.feature-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(95deg,rgba(8,20,15,.93) 0%,rgba(8,20,15,.72) 44%,rgba(10,44,32,.26) 100%),radial-gradient(48% 70% at 86% 8%,rgba(174,240,63,.16),transparent 70%)}
.feature-inner{position:relative;z-index:2;padding:60px 26px}
.feature-band h2{font-weight:900;font-size:clamp(30px,4.6vw,58px);line-height:1.0;letter-spacing:-0.04em;max-width:16ch}
.feature-band p{margin-top:18px;max-width:48ch;font-size:18px;font-weight:500;color:#dcebe1;line-height:1.6}
.feature-band .btn{margin-top:28px}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* ---- responsive ---- */
@media (max-width:1000px){
  .num-grid{grid-template-columns:repeat(2,1fr)}
  .sys-grid{grid-template-columns:1fr;max-width:520px;margin:0 auto}
  .panel-grid{grid-template-columns:1fr;gap:34px}
  .bf-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr);gap:26px}
  .proj-grid{grid-template-columns:1fr 1fr}
  .quote-grid{grid-template-columns:1fr;gap:32px}
}
@media (max-width:680px){
  .nav-links{display:none}
  .topbar-meta{display:none}
  .hero-inner{padding:96px 22px}
  .hero-stats{gap:10px}
  .hero-stats>div{flex:1 1 40%}
  .num-grid{grid-template-columns:1fr}
  .bf-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .proj-grid{grid-template-columns:1fr}
  .quote-form .row{grid-template-columns:1fr;gap:0}
  .footer-inner{grid-template-columns:1fr;gap:30px}
}
