/* ============================================================
   PERSPICAZ MX — Sistema corporativo (estilo certificadora)
   Marca: mostaza + gris + blanco · acento temático por norma
   Tipografía: Manrope (títulos) + Inter (texto)
   ============================================================ */
:root{
    /* Marca / chrome */
    --mustard:#E0A526; --mustard-dark:#C68F1C; --mustard-soft:#FBF3DF;
    --ink:#23272E; --body:#474D56; --muted:#828A94; --line:#E4E7EC;
    --bg:#FFFFFF; --bg-alt:#F5F6F8; --charcoal:#23272E; --charcoal-2:#2D323B;
    /* Acento temático (por defecto = mostaza en la home) */
    --accent:#E0A526; --accent-dark:#C68F1C; --accent-soft:#FBF3DF;
    --head:'Manrope',system-ui,sans-serif; --sans:'Inter',system-ui,sans-serif;
    --maxw:1240px; --r:14px;
}
/* Acentos por norma (clase en <body>) */
body.t-calidad{--accent:#1E5FA8;--accent-dark:#184E88;--accent-soft:#EAF1F9}
body.t-seguridad{--accent:#E2541E;--accent-dark:#C2440F;--accent-soft:#FCEDE6}
body.t-inocuidad{--accent:#1F9D55;--accent-dark:#178045;--accent-soft:#E8F6EE}
body.t-proveedores{--accent:#6D49C7;--accent-dark:#5838A8;--accent-soft:#F0EBFA}
body.t-nom035{--accent:#0E9AA7;--accent-dark:#0B7E89;--accent-soft:#E4F4F5}
body.t-ambiente{--accent:#2E8B57;--accent-dark:#246F45;--accent-soft:#E8F3EC}
body.t-otero{--accent:#4F46E5;--accent-dark:#3D34C7;--accent-soft:#ECEBFB}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--body);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--head);color:var(--ink);line-height:1.12;letter-spacing:-.02em;font-weight:800}
::selection{background:var(--accent);color:#fff}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 2rem}
.idx{font-family:var(--sans);font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}

/* ---- NAV ---- */
nav.site-nav{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;justify-content:space-between;
    padding:.85rem 2rem;background:#fff;border-bottom:1px solid var(--line);transition:box-shadow .3s}
nav.site-nav.scrolled{box-shadow:0 6px 24px rgba(35,39,46,.07)}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--head);font-weight:800;font-size:1.18rem;color:var(--ink);letter-spacing:-.02em}
.brand img{height:38px;width:auto}
.brand b{color:var(--mustard)}
.nav-links{display:flex;align-items:center;gap:1.25rem}
/* Nav colapsa a menú en pantallas medianas (muchos servicios) */
@media(max-width:1140px){
    nav.site-nav .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;gap:1rem;background:#fff;padding:1.4rem 2rem;border-bottom:1px solid var(--line);box-shadow:0 12px 24px rgba(35,39,46,.08)}
    nav.site-nav .nav-links.open{display:flex}
    nav.site-nav .burger{display:flex}
}
.nav-links a{font-size:.88rem;font-weight:500;color:var(--body);position:relative;padding:.3rem 0;white-space:nowrap;transition:color .2s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-.2rem;height:2px;width:0;background:var(--mustard);transition:width .25s}
.nav-links a:hover{color:var(--ink)}.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--ink);font-weight:600}.nav-links a.active::after{width:100%}
.nav-cta{display:inline-flex;align-items:center;gap:.45rem;font-size:.86rem;font-weight:700;color:var(--ink)!important;background:var(--mustard);padding:.6rem 1.2rem;border-radius:8px;transition:background .2s,transform .2s}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--mustard-dark)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px}

/* ---- BUTTONS ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-size:.95rem;font-weight:600;padding:.85rem 1.6rem;border-radius:8px;cursor:pointer;border:2px solid transparent;transition:background .2s,color .2s,border-color .2s,transform .2s}
.btn-solid{background:var(--accent);color:#fff}
.btn-solid:hover{background:var(--accent-dark)}
.btn-line{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-line:hover{border-color:var(--ink)}
.btn-mustard{background:var(--mustard);color:var(--ink)}
.btn-mustard:hover{background:var(--mustard-dark)}
.btn-white{background:#fff;color:var(--ink)}
.btn-white:hover{background:var(--bg-alt)}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost-light:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn .ar{transition:transform .2s}.btn:hover .ar{transform:translateX(4px)}

/* ---- SECTION SHELL ---- */
section.blk{padding:5.5rem 0}
.bg-alt{background:var(--bg-alt)}
.sec-head{margin-bottom:2.6rem;max-width:60ch}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head .idx{display:block;margin-bottom:.7rem}
.sec-head h2{font-size:clamp(1.8rem,3.6vw,2.7rem);font-weight:800}
.sec-head h2 em{font-style:normal;color:var(--accent)}
.sec-head p.lead{font-size:1.06rem;color:var(--body);margin-top:.8rem;max-width:60ch}
.sec-head.center p.lead{margin-left:auto;margin-right:auto}

/* dark variant */
.section-dark{background:var(--charcoal);color:#cfd3d9}
.section-dark h2,.section-dark h3{color:#fff}
.section-dark .sec-head h2 em{color:var(--mustard)}
.section-dark .idx{color:var(--mustard)}
.section-dark .sec-head p.lead{color:rgba(255,255,255,.65)}

/* ============================================================
   HOME HERO (imagen + overlay)
   ============================================================ */
.hero{position:relative;min-height:84vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--charcoal)}
.hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,rgba(22,25,30,.95) 0%,rgba(22,25,30,.86) 38%,rgba(22,25,30,.5) 100%)}
.hero .wrap{position:relative;z-index:1;padding-top:6rem;padding-bottom:3rem}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--mustard);margin-bottom:1.3rem}
.hero-eyebrow::before{content:'';width:28px;height:2px;background:var(--mustard)}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:800;color:#fff;max-width:16ch;letter-spacing:-.03em}
.hero h1 em{font-style:normal;color:var(--mustard)}
.hero-sub{font-size:1.2rem;color:rgba(255,255,255,.78);max-width:50ch;margin:1.5rem 0 2.2rem;line-height:1.6}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.hero-trust{display:flex;gap:2.2rem;flex-wrap:wrap;align-items:center;border-top:1px solid rgba(255,255,255,.15);padding-top:1.6rem}
.hero-trust .ht{display:flex;flex-direction:column}
.hero-trust .ht b{font-family:var(--head);font-size:1.5rem;color:#fff;font-weight:800}
.hero-trust .ht span{font-size:.78rem;color:rgba(255,255,255,.6)}

/* ---- TRUST / ACCREDITATION STRIP ---- */
.strip{background:var(--bg-alt);border-bottom:1px solid var(--line)}
.strip .wrap{display:flex;align-items:center;gap:2rem;flex-wrap:wrap;justify-content:center;padding:1.5rem 2rem}
.strip span{font-size:.82rem;font-weight:600;color:var(--muted);letter-spacing:.02em}
.strip .dot{width:5px;height:5px;border-radius:50%;background:var(--mustard)}

/* ============================================================
   FEATURED CARDS (imagen + overlay + título)  — estilo Intertek
   ============================================================ */
.fcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:1.4rem}
.fcard{position:relative;min-height:360px;border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;isolation:isolate;background:var(--charcoal);transition:transform .3s,box-shadow .3s}
.fcard:hover{transform:translateY(-4px);box-shadow:0 22px 50px rgba(35,39,46,.18)}
.fcard-bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;transition:transform .6s ease}
.fcard:hover .fcard-bg{transform:scale(1.06)}
.fcard::after{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,22,26,.15) 0%,rgba(20,22,26,.62) 55%,rgba(20,22,26,.93) 100%)}
.fcard-bar{position:absolute;top:0;left:0;height:5px;width:100%;background:var(--fc,var(--mustard));z-index:1}
.fcard-body{padding:1.9rem;position:relative;z-index:1}
.fcard .tagk{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--fc,var(--mustard))}
.fcard h3{color:#fff;font-size:1.55rem;margin:.5rem 0 .6rem}
.fcard p{font-size:.92rem;color:rgba(255,255,255,.85);line-height:1.55;margin-bottom:1.1rem;max-width:34ch}
.fcard .more{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;font-size:.9rem;color:#fff}
.fcard .more .ar{transition:transform .25s}
.fcard:hover .more .ar{transform:translateX(5px)}

/* ============================================================
   CAPABILITIES (icono + texto)
   ============================================================ */
.caps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.cap{padding:1.8rem;border:1px solid var(--line);border-radius:var(--r);background:#fff;transition:box-shadow .3s,transform .3s,border-color .3s}
.cap:hover{box-shadow:0 16px 36px rgba(35,39,46,.08);transform:translateY(-3px);border-color:#fff}
.cap .ic{width:50px;height:50px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;margin-bottom:1.1rem}
.cap .ic svg{width:25px;height:25px}
.cap h3{font-size:1.12rem;margin-bottom:.4rem}
.cap p{font-size:.9rem;color:var(--muted);line-height:1.55}

/* ============================================================
   INDUSTRIES (mosaico de imágenes)
   ============================================================ */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.ind{position:relative;height:190px;border-radius:12px;overflow:hidden;display:flex;align-items:flex-end;color:#fff;isolation:isolate}
.ind-bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;transition:transform .6s}
.ind:hover .ind-bg{transform:scale(1.07)}
.ind::after{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,22,26,0) 28%,rgba(20,22,26,.86) 100%)}
.ind span{position:relative;z-index:1;padding:1.1rem 1.2rem;font-family:var(--head);font-weight:700;font-size:1.05rem}

/* ============================================================
   STATS BAND
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.stat .v{font-family:var(--head);font-weight:800;font-size:clamp(2.4rem,4.5vw,3.4rem);color:var(--mustard);letter-spacing:-.02em;line-height:1}
.stat .k{font-size:.92rem;color:rgba(255,255,255,.7);margin-top:.5rem;max-width:22ch}

/* ============================================================
   PAGE HERO (interior) — banda con acento temático
   ============================================================ */
.page-hero{padding:8.5rem 0 3.5rem;background:var(--accent-soft);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:0;left:0;height:6px;width:100%;background:var(--accent)}
.page-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.page-hero .eyebrow{display:inline-block;margin-bottom:1rem}
.page-hero h1{font-size:clamp(2.3rem,5vw,3.7rem);font-weight:800;margin-bottom:1.1rem}
.page-hero h1 em{font-style:normal;color:var(--accent)}
.page-hero .lead{font-size:1.14rem;color:var(--body);max-width:46ch;line-height:1.55;margin-bottom:1.8rem}
.page-hero-actions{display:flex;gap:.9rem;flex-wrap:wrap}

/* panel (checklist) */
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.6rem;box-shadow:0 16px 40px rgba(35,39,46,.08)}
.panel-head{font-family:var(--head);font-size:1rem;font-weight:700;color:var(--ink);padding-bottom:.9rem;margin-bottom:.3rem;border-bottom:1px solid var(--line)}
.panel-row{display:flex;align-items:center;gap:.85rem;padding:.8rem 0;border-bottom:1px solid var(--line);font-size:.9rem}
.panel-row:last-child{border-bottom:none}
.panel-name{flex:1;color:var(--body)}
.panel-mark{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}
.panel-mark svg{width:13px;height:13px}
.mk-done{background:var(--accent);color:#fff}
.mk-now{background:var(--accent-soft);color:var(--accent)}
.mk-wait{background:var(--bg-alt);color:var(--muted)}
.panel-status{font-size:.66rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:600}
.panel-status.done{color:var(--accent)}

/* ---- OTERO (producto de datos/IA): hero oscuro + tablero en vivo ---- */
.page-hero.dark{background:radial-gradient(900px 520px at 85% 8%,rgba(79,70,229,.32),transparent 60%),linear-gradient(135deg,#1b1e25 0%,#23272E 55%,#1a1d24 100%);border-bottom:none;color:#fff}
.page-hero.dark h1{color:#fff}
.page-hero.dark h1 em{color:#9D97FF}
.page-hero.dark .eyebrow,.page-hero.dark .idx{color:#9D97FF}
.page-hero.dark .lead{color:rgba(255,255,255,.74)}
.page-hero.dark .btn-line{color:#fff;border-color:rgba(255,255,255,.4)}
.page-hero.dark .btn-line:hover{background:#fff;color:var(--ink);border-color:#fff}
.otero-def{margin-top:1.6rem;font-size:.82rem;color:rgba(255,255,255,.5);max-width:42ch;line-height:1.5}
.otero-def b{color:rgba(255,255,255,.8);font-weight:600}
.dash{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.3rem;box-shadow:0 30px 70px rgba(0,0,0,.4)}
.dash-top{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--muted);padding-bottom:.85rem;border-bottom:1px solid var(--line);margin-bottom:1rem}
.dash-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.2);animation:pulseDot 1.8s ease-in-out infinite}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 3px rgba(34,197,94,.2)}50%{box-shadow:0 0 0 6px rgba(34,197,94,.05)}}
.dash-top .live{font-weight:700;color:var(--ink)}
.dash-time{margin-left:auto;font-weight:500}
.dash-kpis{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-bottom:1.1rem}
.kpi{background:var(--bg-alt);border-radius:10px;padding:.75rem .85rem}
.kpi .v{font-family:var(--head);font-weight:800;font-size:1.45rem;color:var(--ink);letter-spacing:-.02em}
.kpi .v span{font-size:.85rem;color:var(--accent);font-weight:700}
.kpi .k{font-size:.7rem;color:var(--muted);margin-top:.15rem}
.dash-label{font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem}
.bars{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}
.bar{display:grid;grid-template-columns:58px 1fr 38px;align-items:center;gap:.6rem;font-size:.8rem;color:var(--body)}
.bar .track{height:8px;background:var(--bg-alt);border-radius:100px;overflow:hidden}
.bar .track i{display:block;height:100%;background:var(--accent);border-radius:100px}
.bar b{font-weight:700;color:var(--ink);text-align:right;font-size:.76rem}
.dash-mini{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-bottom:1rem}
.dash-mini > div{border:1px solid var(--line);border-radius:10px;padding:.6rem .75rem}
.dash-mini .mv{font-family:var(--head);font-weight:800;font-size:1.1rem;color:var(--ink)}
.dash-mini .mk{font-size:.68rem;color:var(--muted);margin-top:.1rem}
.dash-alert{display:flex;align-items:center;gap:.5rem;background:#FEF3F2;border:1px solid #FECDCA;color:#B42318;border-radius:8px;padding:.6rem .7rem;font-size:.76rem;font-weight:500}
.dash-alert svg{width:15px;height:15px;flex-shrink:0}

/* Otero — banner tipo landing con mockup de chat (agente IA) */
.hero-split{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;width:100%}
.chat{background:#fff;border-radius:18px;box-shadow:0 30px 70px rgba(0,0,0,.45);overflow:hidden;max-width:430px;margin-left:auto;border:1px solid rgba(255,255,255,.35)}
.chat-head{display:flex;align-items:center;gap:.6rem;padding:.85rem 1.1rem;border-bottom:1px solid var(--line);font-size:.86rem;font-weight:700;color:var(--ink)}
.chat-head .ai{width:28px;height:28px;border-radius:8px;background:var(--accent);color:#fff;display:grid;place-items:center}
.chat-head .ai svg{width:16px;height:16px}
.chat-head .st{margin-left:auto;display:flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:500;color:var(--muted)}
.chat-head .st i{width:7px;height:7px;border-radius:50%;background:#22c55e;display:inline-block;animation:pulseDot 1.8s ease-in-out infinite}
.chat-body{padding:1.1rem;display:flex;flex-direction:column;gap:.7rem;background:var(--bg-alt)}
.msg{max-width:90%;font-size:.82rem;line-height:1.5;padding:.7rem .85rem;border-radius:14px}
.msg.user{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.msg.bot{align-self:flex-start;background:#fff;color:var(--body);border:1px solid var(--line);border-bottom-left-radius:4px;width:100%}
.msg.bot b{color:var(--ink);font-weight:700}
.chat-chart{margin-top:.7rem;display:flex;flex-direction:column;gap:.42rem}
.chat-bar{display:grid;grid-template-columns:64px 1fr 30px;align-items:center;gap:.5rem;font-size:.72rem;color:var(--muted)}
.chat-bar .track{height:7px;background:var(--bg-alt);border-radius:100px;overflow:hidden}
.chat-bar .track i{display:block;height:100%;background:var(--accent);border-radius:100px}
.chat-bar b{color:var(--ink);text-align:right;font-weight:700;font-size:.7rem}
.chat-note{margin-top:.6rem;font-size:.74rem;color:#B42318;display:flex;gap:.35rem;align-items:flex-start}
.chat-note svg{width:13px;height:13px;flex-shrink:0;margin-top:1px}
.chat-input{display:flex;align-items:center;gap:.5rem;padding:.65rem .8rem;border-top:1px solid var(--line);background:#fff}
.chat-input span.ph{flex:1;font-size:.8rem;color:var(--muted)}
.chat-send{width:30px;height:30px;border-radius:8px;background:var(--accent);color:#fff;display:grid;place-items:center;flex-shrink:0}
.chat-send svg{width:15px;height:15px}
.spark{width:100%;height:46px;margin-top:.7rem;display:block;overflow:visible}
@media(max-width:900px){.hero-split{grid-template-columns:1fr;gap:2.4rem}.chat{margin:0 auto;max-width:430px}}

/* ============================================================
   CARDS (pain / deliverables)
   ============================================================ */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.3rem}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.9rem;transition:box-shadow .3s,transform .3s,border-color .3s}
.card:hover{box-shadow:0 16px 36px rgba(35,39,46,.08);transform:translateY(-3px)}
.card .ic{width:48px;height:48px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;margin-bottom:1.1rem}
.card .ic svg{width:23px;height:23px}
.card h3{font-size:1.15rem;margin-bottom:.5rem}
.card p{font-size:.9rem;color:var(--muted);line-height:1.6}
.section-dark .card{background:var(--charcoal-2);border-color:rgba(255,255,255,.1)}
.section-dark .card:hover{box-shadow:none;border-color:rgba(255,255,255,.22)}
.section-dark .card .ic{background:rgba(224,165,38,.16);color:var(--mustard)}
.section-dark .card p{color:rgba(255,255,255,.6)}
.section-dark .feature-info > p{color:rgba(255,255,255,.72)}
.section-dark .feature-info .checks li{color:rgba(255,255,255,.82)}
.card.flex{display:flex;gap:1rem;align-items:flex-start;padding:1.5rem}
.card.flex .ic{margin-bottom:0;flex-shrink:0;width:42px;height:42px}
.card.flex h3{font-size:1.04rem;margin-bottom:.3rem}
.card.flex p{font-size:.86rem}

/* ============================================================
   METHOD / STEPS
   ============================================================ */
.method-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}
.step{padding:1.6rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);position:relative;transition:box-shadow .3s,transform .3s}
.step:hover{box-shadow:0 16px 36px rgba(35,39,46,.08);transform:translateY(-3px)}
.step .n{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:10px;background:var(--accent);color:#fff;font-family:var(--head);font-weight:800;font-size:1.1rem;margin-bottom:1rem}
.step h3{font-size:1.1rem;margin-bottom:.45rem}
.step p{font-size:.88rem;color:var(--muted);line-height:1.5}

/* ============================================================
   FEATURE ROWS (imagen + texto)
   ============================================================ */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;margin-bottom:5rem}
.feature:last-child{margin-bottom:0}
.feature.flip .feature-info{order:2}.feature.flip .feature-media{order:1}
.feature-info .idx{display:block;margin-bottom:.6rem}
.feature-info h3{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;margin-bottom:.9rem}
.feature-info > p{font-size:.98rem;color:var(--body);line-height:1.65;margin-bottom:1.3rem;max-width:46ch}
.checks{display:flex;flex-direction:column;gap:.65rem;list-style:none}
.checks li{display:flex;align-items:flex-start;gap:.65rem;font-size:.92rem;color:var(--body)}
.chk{width:20px;height:20px;min-width:20px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;margin-top:2px}
.chk svg{width:11px;height:11px}
.feature-media{display:flex;align-items:center;justify-content:center}
.shot-desk{width:100%;border-radius:var(--r);border:1px solid var(--line);box-shadow:0 24px 60px rgba(35,39,46,.14)}
.shot-phone{width:240px;border-radius:28px;border:8px solid var(--ink);box-shadow:0 24px 60px rgba(35,39,46,.2);background:#fff}
.shot-doc{width:100%;max-width:340px;border-radius:12px;border:1px solid var(--line);box-shadow:0 24px 60px rgba(35,39,46,.14)}
.hero-shot{width:100%;border:1px solid var(--line);border-radius:var(--r);box-shadow:0 24px 60px rgba(35,39,46,.14)}

/* ============================================================
   PRICING
   ============================================================ */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;text-align:left}
.plan{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.8rem;position:relative;transition:box-shadow .3s,transform .3s}
.plan:hover{box-shadow:0 16px 36px rgba(35,39,46,.08);transform:translateY(-3px)}
.plan.pop{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.pop-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.3rem .9rem;border-radius:100px}
.plan-name{font-family:var(--head);font-size:1.25rem;font-weight:800;color:var(--ink)}
.plan-desc{font-size:.82rem;color:var(--muted);margin-bottom:1.1rem}
.plan-price{font-family:var(--head);font-size:2.2rem;font-weight:800;color:var(--ink);letter-spacing:-.02em}
.plan-price span{font-family:var(--sans);font-size:.85rem;font-weight:400;color:var(--muted)}
.plan-cta{display:block;text-align:center;margin-top:1.2rem;padding:.8rem;border-radius:8px;font-size:.9rem;font-weight:700;transition:.2s;cursor:pointer}
.plan-cta.fill{background:var(--accent);color:#fff}.plan-cta.fill:hover{background:var(--accent-dark)}
.plan-cta.line{background:#fff;color:var(--ink);border:2px solid var(--line)}.plan-cta.line:hover{border-color:var(--ink)}
.plan-feats{margin-top:1.2rem;padding-top:1.1rem;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:.6rem;list-style:none}
.plan-feats li{display:flex;align-items:flex-start;gap:.55rem;font-size:.86rem;color:var(--body)}
.plan-feats li::before{content:'';width:16px;height:16px;margin-top:3px;flex-shrink:0;background:var(--accent);-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M20 6 9 17l-5-5'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M20 6 9 17l-5-5'/></svg>") center/contain no-repeat;}
.plan-extra{font-size:.76rem;color:var(--muted);margin-top:.9rem;padding-top:.8rem;border-top:1px solid var(--line)}
.pricing-foot{text-align:center;margin-top:1.4rem;font-size:.82rem;color:var(--muted)}

/* ============================================================
   BLOG CARD + ARTICLE
   ============================================================ */
.post-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2.2rem;max-width:720px;margin:0 auto;transition:box-shadow .3s,transform .3s}
.post-card:hover{box-shadow:0 16px 36px rgba(35,39,46,.08);transform:translateY(-3px)}
.post-meta{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-bottom:1rem;font-size:.78rem;color:var(--muted)}
.post-tag{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:.25rem .7rem;border-radius:100px}
.post-card h3{font-size:1.4rem;margin-bottom:.6rem}
.post-card p{font-size:.92rem;color:var(--muted);line-height:1.6;margin-bottom:1rem}
.post-more{font-size:.88rem;font-weight:700;color:var(--accent);display:inline-flex;align-items:center;gap:.4rem}

.article-hero{padding:8.5rem 0 3rem;background:var(--accent-soft);border-bottom:1px solid var(--line);position:relative}
.article-hero::before{content:'';position:absolute;top:0;left:0;height:6px;width:100%;background:var(--accent)}
.article-hero .back{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;color:var(--accent);margin-bottom:1.4rem}
.article-hero .back svg{width:15px;height:15px}
.article-hero .tag-row{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-bottom:1.2rem;font-size:.8rem;color:var(--muted)}
.article-hero h1{font-size:clamp(2rem,4.4vw,3.2rem);font-weight:800;max-width:24ch;margin-bottom:1rem}
.article-hero h1 em{font-style:normal;color:var(--accent)}
.article-hero .adesc{font-size:1.12rem;color:var(--body);max-width:60ch;line-height:1.6}
.article-body{max-width:46rem;margin:0 auto;padding:3.5rem 2rem 5rem}
.article-body h2{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;margin:2.6rem 0 1rem}
.article-body h2 em{font-style:normal;color:var(--accent)}
.article-body h3{font-size:1.25rem;font-weight:700;margin:1.8rem 0 .6rem}
.article-body p{font-size:1.04rem;color:var(--body);line-height:1.8;margin-bottom:1.1rem}
.article-body p strong{color:var(--ink);font-weight:700}
.article-body a{color:var(--accent);font-weight:600;text-decoration:underline;text-underline-offset:3px}
.article-body hr{border:none;border-top:1px solid var(--line);margin:2.6rem 0}
.article-body ul,.article-body ol{margin:0 0 1.1rem 1.3rem;color:var(--body);line-height:1.8}
.article-body li{margin-bottom:.5rem;font-size:1.04rem}
.highlight-box{background:var(--accent-soft);border-left:4px solid var(--accent);border-radius:10px;padding:1.4rem 1.7rem;margin:1.7rem 0}
.highlight-box p{margin-bottom:0;font-family:var(--head);font-size:1.2rem;font-weight:700;color:var(--ink)}
.highlight-box strong{color:var(--accent)}
.data-table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.92rem}
.data-table th{text-align:left;padding:.8rem 1rem;background:var(--bg-alt);border:1px solid var(--line);font-weight:700;color:var(--ink);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em}
.data-table td{padding:.8rem 1rem;border:1px solid var(--line);color:var(--body);line-height:1.6}
.data-table td strong{color:var(--ink)}
.article-cta{background:var(--charcoal);color:#fff;border-radius:var(--r);padding:2.6rem;text-align:center;margin:2.8rem 0}
.article-cta h3{color:#fff;font-size:1.6rem;margin-bottom:.6rem}
.article-cta p{color:rgba(255,255,255,.7);font-size:.98rem;margin-bottom:1.5rem;max-width:46ch;margin-left:auto;margin-right:auto}
.article-cta .btn-solid{background:var(--mustard);color:var(--ink)}
.article-cta .btn-solid:hover{background:var(--mustard-dark)}
.article-footer{font-size:.85rem;color:var(--muted);font-style:italic;margin-top:2.5rem;padding-top:1.4rem;border-top:1px solid var(--line);line-height:1.6}

/* ============================================================
   CLIENTS
   ============================================================ */
.clients-head{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:1.8rem;text-align:center;font-weight:600}
.client-row{display:flex;align-items:center;justify-content:center;gap:3.5rem;flex-wrap:wrap}
.client-row img{height:44px;width:auto;filter:grayscale(1);opacity:.55;transition:filter .3s,opacity .3s}
.client-row img:hover{filter:grayscale(0);opacity:1}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:10px;margin-bottom:.8rem;background:#fff;transition:border-color .2s}
.faq-item.open{border-color:var(--accent)}
.faq-q{width:100%;background:none;border:0;padding:1.15rem 1.3rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-family:var(--head);font-size:1.04rem;font-weight:700;color:var(--ink);cursor:pointer;text-align:left}
.faq-ic{position:relative;width:18px;height:18px;flex-shrink:0}
.faq-ic::before,.faq-ic::after{content:'';position:absolute;background:var(--accent);transition:transform .3s}
.faq-ic::before{top:50%;left:0;width:100%;height:2px;transform:translateY(-50%)}
.faq-ic::after{left:50%;top:0;height:100%;width:2px;transform:translateX(-50%)}
.faq-item.open .faq-ic::after{transform:translateX(-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a-in{padding:0 1.3rem 1.2rem;font-size:.95rem;color:var(--body);line-height:1.7}
.faq-item.open .faq-a{max-height:400px}

/* ============================================================
   CTA BLOCK
   ============================================================ */
.cta{background:var(--charcoal);color:#fff;border-radius:var(--r);padding:4rem 3.5rem;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;top:0;left:0;height:6px;width:100%;background:var(--mustard)}
.cta .idx{color:var(--mustard)}
.cta h2{color:#fff;font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;margin:.8rem 0 1.8rem;max-width:20ch}
.cta h2 em{font-style:normal;color:var(--mustard)}
.cta-actions{display:flex;gap:1rem;flex-wrap:wrap}
.cta-contact{margin-top:2.5rem;display:flex;gap:2.5rem;flex-wrap:wrap;font-size:.9rem;color:rgba(255,255,255,.6)}
.cta-contact a{color:#fff;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:2px;transition:border-color .2s}
.cta-contact a:hover{border-color:var(--mustard)}

/* ============================================================
   FOOTER
   ============================================================ */
footer.site-foot{background:var(--charcoal);color:rgba(255,255,255,.6);padding:3.5rem 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2.5rem}
.foot-brand{font-family:var(--head);font-size:1.4rem;font-weight:800;color:#fff}
.foot-brand b{color:var(--mustard)}
.foot-brand span{display:block;font-family:var(--sans);font-size:.85rem;color:rgba(255,255,255,.5);margin-top:.6rem;max-width:34ch;font-weight:400;line-height:1.6}
.foot-col h4{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mustard);margin-bottom:1rem;font-family:var(--sans);font-weight:700}
.foot-col a{display:block;font-size:.9rem;color:rgba(255,255,255,.6);margin-bottom:.6rem;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:3rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);font-size:.78rem;color:rgba(255,255,255,.4)}

[data-reveal]{will-change:transform,opacity}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:920px){
    .fcards,.caps,.ind-grid,.stats{grid-template-columns:repeat(2,1fr)}
    .page-hero-grid{grid-template-columns:1fr;gap:2rem}
    .method-grid{grid-template-columns:repeat(2,1fr)}
    .grid-3,.pricing-grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}
    .grid-2{grid-template-columns:1fr}
    .feature{grid-template-columns:1fr;gap:2rem}
    .feature.flip .feature-info{order:1}.feature.flip .feature-media{order:2}
    .foot-grid{grid-template-columns:1fr 1fr}
    .cta{padding:3rem 2rem}
}
@media(max-width:680px){
    .wrap{padding:0 1.3rem}
    nav.site-nav{padding:.7rem 1.3rem}
    .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;gap:1rem;background:#fff;padding:1.4rem;border-bottom:1px solid var(--line);box-shadow:0 12px 24px rgba(35,39,46,.08)}
    .nav-links.open{display:flex}
    .burger{display:flex}
    .hero{min-height:auto;padding:3rem 0}
    .hero .wrap{padding-top:7rem;padding-bottom:2rem}
    section.blk{padding:3.5rem 0}
    .fcards,.caps,.ind-grid,.stats,.method-grid{grid-template-columns:1fr}
    .foot-grid{grid-template-columns:1fr}
    .hero-trust{gap:1.4rem}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important}}
