/* ============================================================
   LATENT PRECISION — latentprecision.com
   Deep Charcoal × Electric Emerald × Warm Gold
   Precision AI Luxury — Josefin Sans + Source Serif 4
   ============================================================ */

:root {
  --bg:       #09100d;
  --bg2:      #0d1610;
  --bg3:      #111d14;
  --card:     #111a14;
  --card-h:   #162019;
  --bdr:      rgba(52,211,153,.11);
  --bdr-h:    rgba(52,211,153,.32);
  --bdr-g:    rgba(251,191,36,.18);
  --emerald:  #34d399;
  --emerald-d:#10b981;
  --emerald-l:#6ee7b7;
  --gold:     #fbbf24;
  --gold-d:   #f59e0b;
  --gold-l:   #fde68a;
  --txt:      #e8f0eb;
  --txt2:     #6b8a75;
  --txt3:     #2a3d2e;
  --grad:     linear-gradient(135deg,#34d399 0%,#fbbf24 100%);
  --ge:       linear-gradient(90deg,#34d399,#6ee7b7);
  --gg:       linear-gradient(90deg,#fbbf24,#fde68a);
  --geg:      linear-gradient(135deg,#34d399 0%,#fbbf24 100%);
  --f1:       'Josefin Sans',sans-serif;
  --f2:       'Source Serif 4',Georgia,serif;
  --f3:       'DM Sans',sans-serif;
  --r:        10px;
  --r-lg:     16px;
  --r-xl:     22px;
  --ease:     cubic-bezier(.4,0,.2,1);
  --tr:       0.26s var(--ease);
  --tr-s:     0.5s var(--ease);
  --shadow:   0 4px 24px rgba(0,0,0,.5);
  --shadow-e: 0 8px 32px rgba(52,211,153,.18);
  --shadow-g: 0 8px 32px rgba(251,191,36,.18);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow-x:hidden}
body{background:var(--bg);color:var(--txt);font-family:var(--f3);font-size:14px;line-height:1.65}
a{text-decoration:none;color:inherit}
ul{list-style:none}

.ge{background:var(--ge);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gg{background:var(--gg);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.geg{background:var(--geg);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(rgba(52,211,153,.028) 1px,transparent 1px),linear-gradient(90deg,rgba(52,211,153,.028) 1px,transparent 1px);
  background-size:56px 56px;mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 80%)}

.orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(100px);z-index:0}
.o1{width:480px;height:480px;top:-160px;left:-100px;background:radial-gradient(circle,rgba(52,211,153,.09),transparent 70%)}
.o2{width:360px;height:360px;bottom:-100px;right:-60px;background:radial-gradient(circle,rgba(251,191,36,.07),transparent 70%)}
.o3{width:280px;height:280px;top:35%;right:8%;background:radial-gradient(circle,rgba(52,211,153,.055),transparent 70%)}

.page{min-height:100vh;width:100%;display:flex;flex-direction:column;position:relative;overflow:visible}
.main{flex:1;display:flex;align-items:stretch;overflow:visible;position:relative;z-index:1;min-height:0}
.wrap{width:100%;max-width:1380px;margin:0 auto;padding:0 2.5%}

/* NAV */
.nav{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 2.5%;z-index:100;flex-shrink:0;background:rgba(9,16,13,.94);backdrop-filter:blur(24px);border-bottom:1px solid var(--bdr);transition:box-shadow var(--tr),border-color var(--tr)}
.nav.scrolled{box-shadow:0 4px 40px rgba(0,0,0,.6);border-bottom-color:rgba(52,211,153,.2)}
.logo{display:flex;align-items:center;gap:13px;transition:opacity var(--tr)}
.logo:hover{opacity:.85}
.logo-mark{position:relative;width:46px;height:46px;flex-shrink:0}
.logo-mark svg{display:block;width:46px;height:46px}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-name{font-family:var(--f1);font-size:1.18rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--txt)}
.logo-name span{background:var(--ge);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo-sub{font-family:var(--f3);font-size:.6rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--emerald);opacity:.65;margin-top:3px}
.nav-ul{display:flex;align-items:center;gap:2px}
.nav-ul a{font-family:var(--f1);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--txt2);padding:6px 12px;border-radius:6px;transition:color var(--tr),background var(--tr)}
.nav-ul a:hover,.nav-ul a.active{color:var(--emerald);background:rgba(52,211,153,.08)}
.nav-cta{background:var(--grad)!important;color:#09100d!important;-webkit-text-fill-color:#09100d!important;padding:8px 22px!important;border-radius:50px!important;font-weight:700!important;letter-spacing:.06em!important;transition:transform var(--tr),box-shadow var(--tr)!important}
.nav-cta:hover{transform:translateY(-2px)!important;box-shadow:var(--shadow-e)!important}
.burger{display:none;font-size:1.2rem;cursor:pointer;color:var(--txt)}
.mobile-menu{display:none;position:fixed;inset:0;z-index:999;background:rgba(9,16,13,.98);flex-direction:column;align-items:center;justify-content:center;gap:28px;backdrop-filter:blur(20px)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--f1);font-size:1.6rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--txt);transition:color var(--tr)}
.mobile-menu a:hover{color:var(--emerald)}
.mobile-close{position:absolute;top:20px;right:24px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--txt2)}

/* FOOTER */
.foot{min-height:46px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:4px;padding:8px 2.5%;flex-shrink:0;background:rgba(13,22,16,.96);border-top:1px solid var(--bdr);font-size:.7rem;color:var(--txt3);z-index:100;font-family:var(--f1);letter-spacing:.04em}
.foot a{color:var(--txt3);transition:color var(--tr)}
.foot a:hover{color:var(--emerald)}
.foot-links{display:flex;gap:18px;flex-wrap:wrap}
.foot-right{color:var(--gold);font-weight:600}
.foot-right a{color:var(--gold);transition:opacity var(--tr)}
.foot-right a:hover{opacity:.75}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--f1);font-weight:700;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;padding:10px 26px;border-radius:50px;cursor:pointer;white-space:nowrap;transition:transform var(--tr),box-shadow var(--tr),background var(--tr),border-color var(--tr)}
.be{background:var(--grad);color:#09100d}
.be:hover{transform:translateY(-2px);box-shadow:var(--shadow-e)}
.bg_{background:linear-gradient(135deg,var(--gold-d),var(--gold));color:#09100d}
.bg_:hover{transform:translateY(-2px);box-shadow:var(--shadow-g)}
.bo{border:1px solid var(--emerald);color:var(--emerald)}
.bo:hover{background:rgba(52,211,153,.1);box-shadow:var(--shadow-e);transform:translateY(-1px)}
.boo{border:1px solid var(--bdr);color:var(--txt2)}
.boo:hover{border-color:var(--bdr-h);color:var(--emerald);transform:translateY(-1px)}

/* TAG */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--f1);font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--emerald);border:1px solid rgba(52,211,153,.25);background:rgba(52,211,153,.07);padding:4px 13px;border-radius:50px;margin-bottom:10px}
.tag-g{display:inline-flex;align-items:center;gap:6px;font-family:var(--f1);font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(251,191,36,.25);background:rgba(251,191,36,.07);padding:4px 13px;border-radius:50px;margin-bottom:10px}

/* HERO */
.hero-inner{display:grid;grid-template-columns:1fr 1.2fr;align-items:center;gap:32px;width:100%;padding:0 2.5%;position:relative;z-index:2}
.hbadge{display:inline-flex;align-items:center;gap:8px;font-family:var(--f1);font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(251,191,36,.28);background:rgba(251,191,36,.07);padding:5px 14px 5px 10px;border-radius:50px;margin-bottom:16px}
.hbadge .dot{width:5px;height:5px;background:var(--gold);border-radius:50%;animation:pulse 2s infinite}
.hero-l h1{font-family:var(--f1);font-size:clamp(1.9rem,3.6vw,3.2rem);font-weight:700;line-height:1.06;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.hero-l p{font-size:.9rem;color:var(--txt2);line-height:1.8;margin-bottom:24px;max-width:460px}
.hbtns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.precision-divider{display:flex;align-items:center;gap:12px;margin:0 0 14px}
.pd-line{flex:1;height:1px;background:linear-gradient(90deg,rgba(52,211,153,.35),transparent)}
.pd-line.rev{background:linear-gradient(90deg,transparent,rgba(52,211,153,.35))}
.pd-text{font-family:var(--f1);font-size:.58rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(52,211,153,.65);white-space:nowrap}
.hero-strips{display:flex;flex-direction:column;gap:8px}
.hs-strip{display:flex;align-items:flex-start;gap:14px;background:rgba(17,26,20,.8);border:1px solid var(--bdr);border-radius:var(--r);padding:13px 16px;transition:border-color var(--tr),background var(--tr),transform var(--tr),box-shadow var(--tr)}
.hs-strip:hover{border-color:var(--bdr-h);background:var(--card-h);transform:translateX(5px);box-shadow:var(--shadow-e)}
.hss-icon{font-size:1.3rem;flex-shrink:0;margin-top:2px}
.hss-label{font-family:var(--f1);font-size:.74rem;font-weight:700;color:var(--txt);letter-spacing:.04em;margin-bottom:4px;text-transform:uppercase}
.hss-val{font-family:var(--f3);font-size:.72rem;color:var(--txt2);line-height:1.6}

/* LATENT VISUAL */
.latent-wrap{position:relative;width:100%;display:flex;flex-direction:column;gap:10px;align-items:stretch}
.latent-top-chips{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.latent-bot-chips{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.lchip{background:rgba(17,26,20,.85);border:1px solid var(--bdr);border-radius:var(--r);padding:9px 12px;display:flex;align-items:center;gap:8px;transition:border-color var(--tr),background var(--tr),transform var(--tr)}
.lchip:hover{border-color:var(--bdr-h);background:var(--card-h);transform:translateY(-2px)}
.lchip-icon{font-size:.9rem;flex-shrink:0}
.lchip-label{font-family:var(--f1);font-size:.6rem;font-weight:700;color:var(--txt);letter-spacing:.04em;text-transform:uppercase;line-height:1.3}
.lchip-sub{font-family:var(--f3);font-size:.56rem;color:var(--txt2);margin-top:1px;line-height:1.3}
.lstat-chip{background:rgba(17,26,20,.85);border:1px solid rgba(251,191,36,.18);border-radius:var(--r);padding:10px 16px;display:flex;align-items:center;gap:12px;transition:border-color var(--tr),background var(--tr),transform var(--tr)}
.lstat-chip:hover{border-color:rgba(251,191,36,.38);transform:translateY(-2px);background:var(--card-h)}
.lstat-num{font-family:var(--f1);font-size:1.15rem;font-weight:700;background:var(--gg);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;flex-shrink:0;letter-spacing:.02em}
.lstat-label{font-family:var(--f1);font-size:.6rem;font-weight:700;color:var(--txt);letter-spacing:.06em;text-transform:uppercase;line-height:1.4}
.latent-svg-wrap{width:100%;flex:1;border-radius:var(--r-xl);border:1px solid rgba(52,211,153,.18);background:linear-gradient(160deg,rgba(11,20,14,.97) 0%,rgba(9,16,13,.99) 100%);overflow:hidden;min-height:280px;position:relative}
.latent-svg{width:100%;height:100%;min-height:280px;display:block}

/* PAGE HERO */
.ph{padding:14px 2.5% 16px;flex-shrink:0;background:var(--bg2);border-bottom:1px solid var(--bdr);position:relative;z-index:2}
.ph::after{content:'';position:absolute;bottom:0;left:2.5%;right:2.5%;height:1px;background:var(--grad);opacity:.4}
.ph h1{font-family:var(--f1);font-size:clamp(1.3rem,2.6vw,2rem);font-weight:700;letter-spacing:.06em;text-transform:uppercase;line-height:1.1;max-width:640px;margin-bottom:7px}
.ph p{font-size:.82rem;color:var(--txt2);max-width:500px;line-height:1.65}

/* MARQUEE */
.mq{overflow:hidden;padding:10px 0;background:var(--bg2);border-top:1px solid var(--bdr);flex-shrink:0}
.mq-t{display:flex;gap:30px;white-space:nowrap;animation:mq 28s linear infinite;width:max-content}
.mq-t span{font-family:var(--f1);font-size:.64rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--txt2)}
.gem{color:var(--emerald)!important;font-size:.4rem!important;vertical-align:middle}

/* SECTION */
.sec-label{font-family:var(--f1);font-size:.6rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--emerald);margin-bottom:7px}
.sec-h{font-family:var(--f1);font-size:clamp(1rem,1.8vw,1.5rem);font-weight:700;letter-spacing:.04em;text-transform:uppercase;line-height:1.15;margin-bottom:8px}
.sec-p{font-size:.82rem;color:var(--txt2);line-height:1.75;margin-bottom:14px}

/* CARDS */
.card{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r-lg);padding:20px 18px;position:relative;overflow:hidden;transition:border-color var(--tr),background var(--tr),transform var(--tr),box-shadow var(--tr);cursor:default}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.card:hover{border-color:var(--bdr-h);background:var(--card-h);transform:translateY(-4px);box-shadow:var(--shadow-e)}
.card:hover::before{transform:scaleX(1)}
a.card:hover{cursor:pointer}
.card-icon{width:42px;height:42px;border-radius:10px;background:rgba(52,211,153,.1);border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:12px;transition:background var(--tr),border-color var(--tr),transform var(--tr)}
.card:hover .card-icon{background:rgba(52,211,153,.18);border-color:rgba(52,211,153,.3);transform:scale(1.1)}
.card h3{font-family:var(--f1);font-size:.85rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:7px;color:var(--txt)}
.card p{font-size:.78rem;color:var(--txt2);line-height:1.6}
.card .arrow{display:inline-block;margin-top:10px;font-family:var(--f1);font-size:.68rem;font-weight:700;color:var(--emerald);opacity:0;transform:translateX(-6px);transition:opacity var(--tr),transform var(--tr);letter-spacing:.06em;text-transform:uppercase}
.card:hover .arrow{opacity:1;transform:translateX(0)}
.ncard .num{font-family:var(--f1);font-size:1.8rem;font-weight:700;color:var(--txt3);line-height:1;margin-bottom:8px;transition:color var(--tr);letter-spacing:.04em}
.ncard:hover .num{color:rgba(52,211,153,.25)}
.srv-card,.sol-card{cursor:pointer}

/* INFOBOX */
.infobox{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r-lg);padding:18px 16px;transition:border-color var(--tr),background var(--tr),box-shadow var(--tr),transform var(--tr)}
.infobox:hover{border-color:var(--bdr-h);background:var(--card-h);box-shadow:var(--shadow-e);transform:translateY(-2px)}
.iicon{font-size:1.4rem;margin-bottom:9px;transition:transform var(--tr)}
.infobox:hover .iicon{transform:scale(1.12)}
.infobox h3{font-family:var(--f1);font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px;color:var(--txt)}
.infobox p,.infobox a{font-size:.78rem;color:var(--txt2);line-height:1.65}
.infobox::before{content:'';display:block;height:2px;background:var(--grad);border-radius:1px;margin-bottom:14px}

/* VBOX */
.vbox{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r-lg);padding:20px 18px;display:flex;flex-direction:column;gap:11px;transition:border-color var(--tr),box-shadow var(--tr),transform var(--tr);position:relative;overflow:hidden}
.vbox::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad)}
.vbox:hover{border-color:var(--bdr-h);box-shadow:var(--shadow-e);transform:translateY(-2px)}
.vbox-icon{font-size:1.8rem;text-align:center}
.vbox h3{font-family:var(--f1);font-size:.84rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-align:center}
.vbox p{font-size:.77rem;color:var(--txt2);text-align:center;line-height:1.65}

/* CTA BOX */
.cta-box{background:linear-gradient(135deg,rgba(52,211,153,.1),rgba(251,191,36,.06));border:1px solid rgba(52,211,153,.2);border-radius:var(--r-xl);padding:22px 20px;text-align:center;position:relative;overflow:hidden;transition:border-color var(--tr),box-shadow var(--tr),transform var(--tr)}
.cta-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad)}
.cta-box:hover{border-color:rgba(52,211,153,.35);box-shadow:var(--shadow-e);transform:translateY(-2px)}
.cta-box h2{font-family:var(--f1);font-size:1rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:7px}
.cta-box p{font-size:.78rem;color:var(--txt2);margin-bottom:16px;line-height:1.65}

/* PIPELINE */
.pstep{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--bdr);border-radius:var(--r);padding:9px 14px;margin-bottom:7px;transition:border-color var(--tr),background var(--tr),transform var(--tr),box-shadow var(--tr)}
.pstep:hover{border-color:var(--bdr-h);background:var(--card-h);transform:translateX(5px);box-shadow:var(--shadow-e)}
.pn{font-family:var(--f1);font-size:.72rem;font-weight:700;background:var(--ge);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;min-width:20px;letter-spacing:.04em}
.pt{font-size:.76rem;color:var(--txt2);font-family:var(--f3)}
.tc{text-align:center}
.tc h3{font-family:var(--f1);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase}
.tc p{font-size:.72rem}

/* GRIDS */
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:100%}
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;width:100%}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;width:100%}

/* MODALS */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(9,16,13,.88);backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity var(--tr)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--bg2);border:1px solid var(--bdr-h);border-radius:var(--r-xl);padding:32px 28px;max-width:540px;width:92%;position:relative;box-shadow:0 32px 80px rgba(0,0,0,.7);transform:translateY(22px) scale(.97);transition:transform .32s var(--ease);overflow:hidden}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-box::before{content:'';display:block;height:2px;background:var(--grad);border-radius:2px;margin-bottom:20px}
.modal-close{position:absolute;top:14px;right:16px;background:rgba(255,255,255,.05);border:1px solid var(--bdr);border-radius:6px;color:var(--txt2);font-size:.82rem;width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--tr),color var(--tr),border-color var(--tr)}
.modal-close:hover{background:rgba(52,211,153,.12);color:var(--emerald);border-color:var(--bdr-h)}
.modal-icon{font-size:2rem;margin-bottom:8px}
.modal-num{font-family:var(--f1);font-size:1.1rem;font-weight:700;color:var(--txt3);line-height:1;margin-bottom:5px;letter-spacing:.06em}
.modal-title{font-family:var(--f1);font-size:1.2rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;background:var(--geg);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.modal-summary{font-size:.84rem;color:var(--txt2);line-height:1.7;margin-bottom:14px}
.modal-list{list-style:none;display:flex;flex-direction:column;gap:8px}
.modal-list li{font-size:.8rem;color:var(--txt2);line-height:1.65;padding:9px 12px 9px 32px;position:relative;background:var(--card);border:1px solid var(--bdr);border-radius:8px;transition:border-color var(--tr),background var(--tr)}
.modal-list li:hover{border-color:var(--bdr-h);background:var(--card-h)}
.modal-list li::before{content:'◆';position:absolute;left:12px;top:10px;font-size:.48rem;color:var(--emerald)}
.modal-list li strong{color:var(--txt)}

/* CONTACT FORM */
.form-wrap{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r-lg);padding:26px 24px;position:relative;overflow:hidden;transition:border-color var(--tr),box-shadow var(--tr)}
.form-wrap::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad)}
.form-wrap:hover{border-color:var(--bdr-h);box-shadow:var(--shadow-e)}
.form-title{font-family:var(--f1);font-size:.88rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--txt);margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}
.form-group label{font-family:var(--f1);font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--txt2)}
.form-group input,.form-group select,.form-group textarea{background:var(--bg2);border:1px solid var(--bdr);border-radius:7px;padding:9px 12px;color:var(--txt);font-family:var(--f3);font-size:.84rem;outline:none;width:100%;transition:border-color var(--tr),box-shadow var(--tr),background var(--tr)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--txt3)}
.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:rgba(52,211,153,.25);background:var(--bg3)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--emerald);box-shadow:0 0 0 3px rgba(52,211,153,.12);background:var(--bg3)}
.form-group select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b8a75' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.form-group select option{background:var(--bg2);color:var(--txt)}
.form-group textarea{resize:none;line-height:1.6}
.form-submit{width:100%;background:var(--grad);color:#09100d;font-family:var(--f1);font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;padding:12px 24px;border:none;border-radius:50px;cursor:pointer;margin-top:4px;transition:transform var(--tr),box-shadow var(--tr);display:flex;align-items:center;justify-content:center;gap:8px}
.form-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-e)}

/* LEGAL */
.legal{font-size:.8rem;color:var(--txt2);line-height:1.8}
.legal h2{font-family:var(--f1);font-size:.88rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--emerald);margin:14px 0 7px}
.legal p,.legal li{margin-bottom:6px}
.legal ul{list-style:disc;padding-left:18px}
.legal a{color:var(--gold);transition:opacity var(--tr)}
.legal a:hover{opacity:.75}

/* CENTERED PAGES */
.centered-page{flex:1;display:flex;align-items:center;justify-content:center;position:relative;z-index:2}
.centered-card{background:var(--card);border:1px solid var(--bdr);border-radius:var(--r-xl);padding:48px 44px;text-align:center;max-width:520px;width:92%;position:relative;overflow:hidden;transition:border-color var(--tr),box-shadow var(--tr);animation:fadeUp .7s ease both}
.centered-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad)}
.centered-card:hover{border-color:var(--bdr-h);box-shadow:var(--shadow-e)}
.cc-icon{font-size:3rem;margin-bottom:16px}
.cc-title{font-family:var(--f1);font-size:1.8rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px}
.cc-text{font-size:.88rem;color:var(--txt2);line-height:1.75;margin-bottom:20px}
.cc-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.cc-email{display:block;margin:8px auto 18px;color:var(--gold);font-family:var(--f1);font-size:.84rem;font-weight:700;letter-spacing:.04em;transition:opacity var(--tr)}
.cc-email:hover{opacity:.75}
.err-num{font-family:var(--f1);font-size:5rem;font-weight:700;line-height:1;background:var(--geg);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px;letter-spacing:.04em}

/* KEYFRAMES */
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;padding:32px 4%}
  .g3,.g4{grid-template-columns:repeat(2,1fr)}
}
/* ── LAPTOP / SMALL DESKTOP (900–1380px) ──
   Screens in this range (13" MacBook, 14" laptop etc.) don't have
   enough vertical height for the locked single-viewport layout.
   Enable graceful scroll so no content is ever clipped or hidden. */
@media(max-width:1380px){
  html,body{overflow-x:hidden;overflow-y:auto}
  .page{min-height:100vh;overflow:visible}
  .main{overflow:visible;min-height:0}
}

@media(max-width:900px){
  html,body{overflow:auto}
  .page{height:auto;min-height:100vh;overflow:visible}
  .main{flex-direction:column;overflow:visible}
  .nav-ul{display:none;position:fixed;top:64px;left:0;right:0;flex-direction:column;background:rgba(9,16,13,.98);padding:14px 4%;gap:4px;border-bottom:1px solid var(--bdr);z-index:99;backdrop-filter:blur(20px)}
  .nav-ul.open{display:flex}
  .burger{display:block}
  .hero-inner{grid-template-columns:1fr;padding:28px 4%}
  .hero-r{display:none}
  .g3,.g4{grid-template-columns:repeat(2,1fr)}
  .g2{grid-template-columns:1fr}
  .foot{flex-direction:column;align-items:flex-start;gap:6px;min-height:auto;padding:12px 4%}
  .foot-links{flex-wrap:wrap;gap:10px}
  .foot-right{margin-left:0}
  .wrap{padding:0 4%}
  .ph{padding:14px 4% 16px}
  .nav{padding:0 4%}
}
@media(max-width:540px){
  .g3,.g4{grid-template-columns:1fr}
  .hero-l h1{font-size:clamp(1.6rem,8vw,2.2rem)}
  .centered-card{padding:36px 22px}
  .form-row{grid-template-columns:1fr}
}
