/*
Theme Name: Compass Pro
Theme URI: https://compasspro.ca
Author: eStatim Inc.
Author URI: https://compasspro.ca
Description: Custom marketing theme for Compass Pro — cloud dental & orthodontic practice management software. Light, technological "friendly SaaS" design with compass-needle gradient motif.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: compass-pro
*/

:root{
  --ink:#0E1230;
  --ink-soft:#3a3f5c;
  --muted:#6b7088;
  --paper:#F7F8FA;
  --paper-2:#eef0f5;
  --hero-grey:#C6CAD2;
  --line:#e3e6ee;
  --white:#ffffff;
  --teal:#1FBFC9;
  --blue:#3A6FE0;
  --violet:#7A33C9;
  --magenta:#B0277E;
  --grad:linear-gradient(105deg,var(--teal) 0%,var(--blue) 45%,var(--violet) 100%);
  --grad-soft:linear-gradient(105deg,rgba(31,191,201,.12),rgba(122,51,201,.12));
  --shadow-sm:0 2px 10px rgba(14,18,48,.06);
  --shadow:0 18px 50px -18px rgba(14,18,48,.28);
  --r:18px;
  --maxw:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:"Inter",system-ui,sans-serif;color:var(--ink);
  background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4{font-family:"Sora",sans-serif;line-height:1.12;margin:0;letter-spacing:-.02em;font-weight:700}
p{margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{font-family:"Sora";font-size:.78rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--violet)}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:"Sora";font-weight:600;font-size:.98rem;
  padding:.85rem 1.5rem;border-radius:999px;cursor:pointer;border:0;transition:transform .18s,box-shadow .18s;white-space:nowrap}
.btn-primary{background:var(--grad);color:#fff!important;text-decoration:none!important;box-shadow:0 10px 24px -8px rgba(58,111,224,.6)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -8px rgba(122,51,201,.55)}
.btn-ghost{background:rgba(255,255,255,.7);color:var(--ink);border:1px solid var(--line);backdrop-filter:blur(6px)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}

/* xs */

/* xs */


/* ---------- scroll progress (compass needle) ---------- */
#progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--grad);z-index:1200}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:1000;transition:background .3s,box-shadow .3s,padding .3s;padding:14px 0}
header.scrolled{background:rgba(247,248,250,.85);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.6rem;font-family:"Sora";font-weight:700;font-size:1.45rem;color:var(--ink);letter-spacing:-.03em}
.brand img{width:38px;height:38px}
.brand span small{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--violet);display:block;margin-top:-4px;font-weight:600}
.menu{display:flex;align-items:center;gap:1.7rem}
.menu a{font-size:.95rem;font-weight:500;color:var(--ink-soft);transition:color .15s}
.menu a:hover{color:var(--blue)}.menu a.btn-primary{color:#fff}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:clamp(560px,86vh,820px);display:flex;align-items:center;overflow:hidden;
  background:var(--hero-grey)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:78% center}
/* left fade so copy sits on clean grey */
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,var(--hero-grey) 0%,var(--hero-grey) 30%,rgba(198,202,210,.72) 46%,rgba(198,202,210,0) 66%)}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}
.hero-copy{max-width:620px}
.hero h1{font-size:clamp(2.2rem,5.2vw,4rem);font-weight:800;margin:.9rem 0 1.1rem}
.hero h1 .grad-text{display:inline}
.hero p.lead{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--ink-soft);max-width:540px;margin-bottom:1.8rem}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-meta{margin-top:2rem;display:flex;gap:1.6rem;flex-wrap:wrap;font-size:.85rem;color:var(--ink-soft)}
.hero-meta b{font-family:"Sora";color:var(--ink)}
.float{animation:float 7s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---------- section base ---------- */
section{position:relative}
.block{padding:clamp(64px,9vw,120px) 0}
.sec-head{max-width:720px;margin-bottom:3rem}
.sec-head h2{font-size:clamp(1.8rem,3.6vw,2.9rem);margin:.6rem 0 1rem}
.sec-head p{color:var(--muted);font-size:1.08rem}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* needle divider */
.needle{height:2px;width:120px;background:var(--grad);border-radius:2px;margin:0 0 0}
.center .needle{margin:0 auto}

/* ---------- video ---------- */
.video-sec{background:linear-gradient(180deg,var(--paper),var(--white));overflow:hidden}
/* full-bleed wider container for the player */
.video-wide{max-width:1480px;margin:0 auto;padding:0 24px}
/* parallax stage: holds the frame and lets it travel as you scroll */
.video-stage{will-change:transform}
.video-frame{position:relative;border-radius:26px;overflow:hidden;box-shadow:0 40px 90px -30px rgba(14,18,48,.45);
  aspect-ratio:16/9;background:#0E1230;width:100%;margin:0 auto;border:1px solid rgba(255,255,255,.1)}
.video-frame video,.video-frame iframe{width:100%;height:100%;object-fit:cover;border:0}
.video-poster{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1.2rem;text-align:center;color:#fff;cursor:pointer;
  background:radial-gradient(120% 120% at 70% 30%,rgba(58,111,224,.45),transparent 60%),
  radial-gradient(120% 120% at 20% 80%,rgba(122,51,201,.4),transparent 55%),#0E1230}
.play{width:84px;height:84px;border-radius:50%;background:var(--grad);display:grid;place-items:center;
  box-shadow:0 0 0 0 rgba(58,111,224,.5);animation:pulse 2.6s infinite}
.play svg{margin-left:5px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(58,111,224,.55)}70%{box-shadow:0 0 0 26px rgba(58,111,224,0)}100%{box-shadow:0 0 0 0 rgba(58,111,224,0)}}
.video-poster h3{font-size:1.5rem;color:#fff}
.video-poster p{color:#c5cae8;max-width:420px}
.video-note{text-align:center;color:var(--muted);font-size:.85rem;margin-top:1rem}

/* ---------- pains ---------- */
.pains{background:var(--white)}
.pain-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.pain{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:2rem 1.9rem;overflow:hidden;transition:transform .25s,box-shadow .25s}
.pain:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pain::before{content:attr(data-n);position:absolute;top:1rem;right:1.3rem;font-family:"Sora";font-weight:800;
  font-size:3.2rem;color:transparent;-webkit-text-stroke:1.5px var(--paper-2);line-height:1}
.pain .ic{width:46px;height:46px;border-radius:12px;background:var(--grad-soft);display:grid;place-items:center;margin-bottom:1rem}
.pain h3{font-size:1.25rem;margin-bottom:.5rem}
.pain p{color:var(--muted);font-size:.98rem}
.imagine{text-align:center;padding:clamp(60px,8vw,110px) 0;background:
  radial-gradient(80% 120% at 50% 0%,rgba(122,51,201,.07),transparent 60%),var(--white)}
.imagine h2{font-size:clamp(1.7rem,4vw,3rem);max-width:760px;margin:0 auto;font-weight:800}

/* ---------- solution reveal ---------- */
.reveal{background:linear-gradient(180deg,var(--ink),#161b40);color:#fff;text-align:center;
  padding:clamp(70px,9vw,120px) 0;position:relative;overflow:hidden}
.reveal .glow{position:absolute;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(58,111,224,.35),transparent 65%);top:-200px;left:50%;transform:translateX(-50%);filter:blur(30px)}
.reveal img.mk{width:74px;margin:0 auto 1.4rem;position:relative}
.reveal h2{font-size:clamp(1.9rem,4vw,3rem);position:relative;font-weight:800}
.reveal p{max-width:640px;margin:1.2rem auto 0;color:#c5cae8;font-size:1.1rem;position:relative}

/* ---------- features ---------- */
.features{background:var(--white)}
.feature{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;padding:clamp(40px,6vw,72px) 0}
.feature:not(:last-child){border-bottom:1px solid var(--line)}
.feature.flip .f-visual{order:2}
.f-text .tag{display:inline-flex;align-items:center;gap:.5rem;font-family:"Sora";font-size:.78rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--violet);margin-bottom:.9rem}
.f-text .tag .dot{width:24px;height:24px;border-radius:7px;background:var(--grad);color:#fff;display:grid;place-items:center;font-size:.7rem}
.f-text h3{font-size:clamp(1.4rem,2.5vw,2rem);margin-bottom:.9rem}
.f-text p{color:var(--muted);font-size:1.05rem}
.f-visual{position:relative}
.mock{border-radius:18px;border:1px solid var(--line);background:var(--paper);box-shadow:var(--shadow);overflow:hidden}
.mock .bar{display:flex;gap:6px;padding:11px 14px;border-bottom:1px solid var(--line);background:var(--white)}
.mock .bar i{width:11px;height:11px;border-radius:50%;background:var(--paper-2)}
.mock .body{padding:18px}
.row{display:flex;align-items:center;gap:.7rem;padding:.6rem .2rem;border-bottom:1px dashed var(--line);font-size:.9rem;color:var(--ink-soft)}
.row:last-child{border:0}
.pill{margin-left:auto;font-family:"Sora";font-size:.72rem;font-weight:600;padding:.2rem .6rem;border-radius:999px}
.pill.green{background:rgba(31,191,201,.15);color:#0f8a92}
.pill.blue{background:rgba(58,111,224,.15);color:var(--blue)}
.pill.violet{background:rgba(122,51,201,.15);color:var(--violet)}
.avatar{width:30px;height:30px;border-radius:8px;background:var(--grad)}
.bars{display:flex;align-items:flex-end;gap:10px;height:120px;padding-top:10px}
.bars span{flex:1;background:var(--grad);border-radius:6px 6px 0 0;opacity:.85}
.kpi{display:flex;gap:1rem;margin-top:1rem}
.kpi div{flex:1;background:var(--white);border:1px solid var(--line);border-radius:12px;padding:.7rem .8rem}
.kpi b{font-family:"Sora";font-size:1.3rem;display:block;color:var(--ink)}
.kpi small{color:var(--muted);font-size:.72rem}
.cal{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.cal i{height:34px;border-radius:7px;background:var(--paper-2)}
.cal i.f{background:var(--grad);opacity:.85}

/* ---------- transformation ---------- */
.transform{background:linear-gradient(180deg,var(--white),var(--paper));text-align:center}
.transform .quote{max-width:820px;margin:0 auto}
.transform h2{font-size:clamp(1.7rem,3.5vw,2.7rem);font-weight:800;margin-bottom:1.2rem}
.transform p{color:var(--muted);font-size:1.1rem}
.t-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem;max-width:760px;margin-left:auto;margin-right:auto}
.t-stats div{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:1.6rem 1rem;box-shadow:var(--shadow-sm)}
.t-stats b{font-family:"Sora";font-size:clamp(1.8rem,4vw,2.6rem);display:block}
.t-stats small{color:var(--muted);font-size:.85rem}

/* ---------- audience ---------- */
.aud{background:var(--white)}
.aud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.aud-card{border:1px solid var(--line);border-radius:14px;padding:1.4rem;background:var(--paper);transition:.22s}
.aud-card:hover{border-color:var(--blue);transform:translateY(-4px)}
.aud-card h4{font-size:1.05rem;margin-bottom:.3rem}
.aud-card p{color:var(--muted);font-size:.9rem}




/* ---------- pricing ---------- */
.pricing{background:var(--paper)}
.plans{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;align-items:stretch}
.plan{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:1.8rem 1.5rem;display:flex;flex-direction:column}
.plan.pop{border:1.5px solid transparent;background:
  linear-gradient(var(--white),var(--white)) padding-box,var(--grad) border-box;box-shadow:var(--shadow);position:relative}
.plan.pop::after{content:"Most popular";position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--grad);color:#fff;font-family:"Sora";font-size:.7rem;font-weight:600;padding:.25rem .8rem;border-radius:999px;letter-spacing:.05em}
.plan h3{font-size:1.2rem}
.plan .sub{color:var(--muted);font-size:.82rem;margin:.2rem 0 1rem;min-height:2.2em}
.plan .price{font-family:"Sora";font-weight:800;font-size:2.1rem}
.plan .price small{font-size:.85rem;font-weight:500;color:var(--muted)}
.plan ul{list-style:none;padding:0;margin:1.2rem 0;display:flex;flex-direction:column;gap:.55rem;font-size:.9rem;color:var(--ink-soft);flex:1}
.plan li{display:flex;gap:.55rem;align-items:flex-start}
.plan li svg{flex:none;margin-top:3px}
.plan .btn{width:100%;justify-content:center;margin-top:auto}
.price-note{text-align:center;color:var(--muted);font-size:.85rem;margin-top:1.6rem}

/* ---------- trust ---------- */
.trust{background:var(--white)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.trust-card{border:1px solid var(--line);border-radius:14px;padding:1.5rem;text-align:center;background:var(--paper)}
.trust-card .ic{width:48px;height:48px;border-radius:12px;background:var(--grad-soft);display:grid;place-items:center;margin:0 auto 1rem}
.trust-card h4{font-size:1rem;margin-bottom:.3rem}
.trust-card p{color:var(--muted);font-size:.85rem}
.badges{display:flex;gap:.7rem;flex-wrap:wrap;justify-content:center;margin-top:2.4rem}
.badge{font-family:"Sora";font-size:.8rem;font-weight:600;padding:.5rem 1rem;border-radius:999px;border:1px solid var(--line);color:var(--ink-soft);background:var(--white)}

/* ---------- final cta ---------- */
.final{background:linear-gradient(160deg,#0E1230,#1a2050);color:#fff;text-align:center;overflow:hidden;position:relative}
.final .glow{position:absolute;width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(122,51,201,.4),transparent 60%);bottom:-300px;left:50%;transform:translateX(-50%);filter:blur(40px)}
.final h2{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;position:relative}
.final p{max-width:750px;margin:1.2rem auto 2rem;color:#c5cae8;font-size:1.1rem;position:relative}
.final .actions{position:relative;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.final .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.2)}
.final small{display:block;margin-top:1.6rem;color:#8a90b8;font-size:.85rem;position:relative}

/* ---------- footer ---------- */
footer{background:var(--paper);border-top:1px solid var(--line);padding:60px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr repeat(4,1fr);gap:2rem}
.foot-brand .brand{margin-bottom:1rem}
.foot-brand p{color:var(--muted);font-size:.9rem;max-width:280px}
.foot-col h5{font-family:"Sora";font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:1rem}
.foot-col a{display:block;color:var(--muted);font-size:.9rem;padding:.25rem 0;transition:color .15s}
.foot-col a:hover{color:var(--blue)}
.foot-bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line);display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:1rem;color:var(--muted);font-size:.82rem}

/* reveal-on-scroll */
.ro{opacity:0;transform:translateY(26px);transition:opacity .7s,transform .7s}
.ro.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .menu,.nav-cta .btn-ghost{display:none}
  .burger{display:flex}
  .menu.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    background:var(--white);padding:1rem 24px 1.5rem;gap:.4rem;box-shadow:var(--shadow);border-top:1px solid var(--line)}
  .menu.open a{padding:.7rem .3rem;border-bottom:1px solid var(--line)}
  .menu.open .btn{margin-top:.6rem}
  .feature,.feature.flip{grid-template-columns:1fr;gap:1.6rem}
  .feature.flip .f-visual{order:0}
  .plans{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .hero{min-height:auto;padding:clamp(48px,12vw,72px) 0}
  .hero-bg img{object-position:72% center;opacity:.5}
  .hero-bg::after{background:linear-gradient(180deg,rgba(198,202,210,.9),rgba(198,202,210,.78))}
  .pain-grid{grid-template-columns:1fr}
  .aud-grid{grid-template-columns:1fr}
  .t-stats{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:1fr}
  .video-wide{padding:0 16px}
  .video-frame{border-radius:18px}
}
@media(max-width:520px){
  .plans{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
  .ro{opacity:1;transform:none}
}

/* ===== inner-page styles ===== */


/* ---------- minimal header (shared) ---------- */
header{position:sticky;top:0;z-index:1000;background:rgba(247,248,250,.85);backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line);padding:12px 0}

.menu a.active{color:var(--ink);font-weight:600}


/* ---------- page hero (compact) ---------- */
.page-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  padding:clamp(40px,7vw,84px) 0;background:var(--paper)}

.page-hero::before{content:"";position:absolute;inset:0;z-index:0;
  background:var(--caption-bg) no-repeat right center;background-size:cover}

.page-hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,var(--paper) 0%,var(--paper) 26%,rgba(247,248,250,.78) 44%,rgba(247,248,250,0) 66%)}

.page-hero>.wrap{position:relative;z-index:2}

.crumbs{font-size:.85rem;color:var(--muted);margin-bottom:1.1rem;display:flex;gap:.5rem;align-items:center}

.crumbs a:hover{color:var(--blue)}

.crumbs span{color:var(--paper-2)}

.crumbs span.sep{color:var(--muted)}

.page-hero h1{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:800;max-width:780px;margin:.4rem 0 1rem}

.page-hero p.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--ink-soft);max-width:640px}

.needle{height:2px;width:120px;background:var(--grad);border-radius:2px}


/* ---------- article body ---------- */
.article{padding:clamp(48px,7vw,90px) 0}

.article-grid{display:grid;grid-template-columns:230px 1fr;gap:3.5rem;align-items:start}

/* sticky in-page nav */
.toc{position:sticky;top:90px;font-size:.9rem}

.toc h5{font-family:"Sora";font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}

.toc a{display:block;color:var(--muted);padding:.4rem 0 .4rem .9rem;border-left:2px solid var(--line);transition:.15s}

.toc a:hover,.toc a.on{color:var(--ink);border-color:var(--blue)}

.prose{max-width:720px}

.prose h2{font-size:clamp(1.5rem,3vw,2.1rem);margin:2.6rem 0 1rem;scroll-margin-top:90px}

.prose h2:first-child{margin-top:0}

.prose h3{font-size:1.2rem;margin:1.8rem 0 .6rem}

.prose p{color:var(--ink-soft);margin-bottom:1.1rem;font-size:1.05rem}

.prose ul{margin:0 0 1.4rem;padding:0;list-style:none;display:flex;flex-direction:column;gap:.7rem}

.prose ol{margin:0 0 1.4rem;padding-left:1.3rem;color:var(--ink-soft)}

.prose ol li{padding-left:.3rem;margin-bottom:.5rem}

.prose ul li{position:relative;padding-left:1.8rem;color:var(--ink-soft)}

.prose ul li::before{content:"";position:absolute;left:0;top:.62em;width:8px;height:8px;border-radius:2px;
  background:var(--grad);transform:rotate(45deg)}

.prose li b{color:var(--ink)}

.pullquote{margin:2.4rem 0;padding:1.6rem 1.8rem;border-radius:var(--r);background:var(--paper);
  border-left:3px solid transparent;border-image:var(--grad) 1;font-family:"Sora";font-weight:600;
  font-size:1.2rem;color:var(--ink);line-height:1.4}

.principles{display:grid;gap:1rem;margin:1.6rem 0 1.4rem}

.principle{display:flex;gap:1rem;padding:1.2rem 1.3rem;background:var(--paper);border:1px solid var(--line);border-radius:14px}

.principle .num{font-family:"Sora";font-weight:800;font-size:1.3rem;background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;flex:none;line-height:1.3}

.principle h4{font-size:1.05rem;margin-bottom:.2rem}

.principle p{font-size:.95rem;margin:0}


/* cta strip */
.cta-strip{margin-top:3rem;padding:2rem 2.2rem;border-radius:var(--r);background:var(--ink);color:#fff;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
  background:radial-gradient(120% 160% at 100% 0%,rgba(122,51,201,.4),transparent 55%),var(--ink)}

.cta-strip h3{font-size:1.4rem;color:#fff}

.cta-strip p{color:#c5cae8;font-size:.95rem;margin-top:.3rem}


/* ---------- footer (shared) ---------- */
footer{background:var(--paper);border-top:1px solid var(--line);padding:60px 0 30px}


/* ---------- responsive ---------- */
@media(max-width:980px){
  .menu,.nav-cta .btn-ghost{display:none}

  .toc{display:none}

  .cta-strip{flex-direction:column;align-items:flex-start}
} /*xxx*/

/* header */
header{position:sticky;top:0;z-index:1000;background:rgba(247,248,250,.85);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line);padding:12px 0}


/* page hero */
.page-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  padding:clamp(40px,7vw,84px) 0;background:var(--paper)}


/* plans */
.section{padding:clamp(48px,7vw,90px) 0}


/* services tables */
.services{background:var(--paper);border-top:1px solid var(--line)}

.svc{margin-bottom:2.4rem}

.svc h3{font-size:1.25rem;margin-bottom:.4rem}

.svc>p{color:var(--muted);font-size:.95rem;margin-bottom:1.1rem;max-width:760px}

.tbl{width:100%;border-collapse:separate;border-spacing:0;background:var(--white);border:1px solid var(--line);border-radius:14px;overflow:hidden;font-size:.92rem}

.tbl th,.tbl td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--line)}

.tbl thead th{background:var(--paper-2);font-family:"Sora";font-weight:600;color:var(--ink);font-size:.82rem;letter-spacing:.02em}

.tbl tbody tr:last-child td{border-bottom:0}

.tbl td:first-child,.tbl th:first-child{font-weight:600;color:var(--ink);width:140px}

.tbl-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}


/* footer */
footer{background:var(--paper);border-top:1px solid var(--line);padding:60px 0 30px}


@media(max-width:980px){
  .menu,.nav-cta .btn-ghost{display:none}
} /*xxx*/

header{position:sticky;top:0;z-index:1000;background:rgba(247,248,250,.85);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line);padding:12px 0}


.page-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);padding:clamp(40px,7vw,84px) 0;background:var(--paper)}


.section{padding:clamp(48px,7vw,90px) 0}

.faq-grid{display:grid;grid-template-columns:220px 1fr;gap:3.5rem;align-items:start}

.cats{position:sticky;top:90px;font-size:.9rem}

.cats h5{font-family:"Sora";font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}

.cats a{display:block;color:var(--muted);padding:.4rem 0 .4rem .9rem;border-left:2px solid var(--line);transition:.15s}

.cats a:hover,.cats a.on{color:var(--ink);border-color:var(--blue)}

.faq-col{max-width:760px}

.faq-cat{margin-bottom:2.8rem}

.faq-cat>h2{font-size:clamp(1.4rem,2.6vw,1.9rem);margin-bottom:1.2rem;scroll-margin-top:90px}

.qa{border:1px solid var(--line);border-radius:14px;margin-bottom:.8rem;background:var(--white);overflow:hidden;transition:border-color .2s,box-shadow .2s}

.qa[open]{border-color:rgba(58,111,224,.4);box-shadow:var(--shadow-sm)}

.qa summary{list-style:none;cursor:pointer;padding:1.1rem 1.3rem;display:flex;align-items:center;gap:1rem;font-family:"Sora";font-weight:600;font-size:1.02rem;color:var(--ink)}

.qa summary::-webkit-details-marker{display:none}

.qa summary .ic{margin-left:auto;flex:none;width:24px;height:24px;border-radius:7px;background:var(--grad-soft);display:grid;place-items:center;transition:transform .25s}

.qa[open] summary .ic{transform:rotate(45deg)}

.qa .ans{padding:0 1.3rem 1.2rem;color:var(--ink-soft);font-size:1rem}

.qa .ans p{margin-bottom:.7rem}
.qa .ans p:last-child{margin-bottom:0}

.qa .ans ul{margin:.3rem 0 .7rem;padding:0;list-style:none;display:flex;flex-direction:column;gap:.4rem}

.qa .ans li{position:relative;padding-left:1.5rem}

.qa .ans li::before{content:"";position:absolute;left:0;top:.6em;width:7px;height:7px;border-radius:2px;background:var(--grad);transform:rotate(45deg)}

.qa .ans b{color:var(--ink)}


footer{background:var(--paper);border-top:1px solid var(--line);padding:60px 0 30px}

.contact-grid{display:grid;grid-template-columns:1fr 360px;gap:3rem;align-items:start}


/* form */
.form-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:2rem;box-shadow:var(--shadow-sm)}

.form-card h2{font-size:1.4rem;margin-bottom:1.4rem}

.field{margin-bottom:1.1rem}

.row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

label{display:block;font-family:"Sora";font-size:.82rem;font-weight:600;color:var(--ink);margin-bottom:.4rem}

.inp{width:100%;padding:.8rem .95rem;border:1px solid var(--line);border-radius:11px;font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--paper);transition:border-color .15s,box-shadow .15s}

.inp:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(58,111,224,.12);background:var(--white)}

textarea.inp{resize:vertical;min-height:120px}

.radios{display:flex;gap:1.2rem;flex-wrap:wrap;margin-top:.2rem}

.radios label{display:flex;align-items:center;gap:.45rem;font-weight:500;font-family:"Inter";font-size:.92rem;color:var(--ink-soft);cursor:pointer}

.radios input{accent-color:var(--blue)}

.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:var(--muted);margin:.4rem 0 1.3rem}

.consent input{accent-color:var(--blue);margin-top:.25rem}

.form-card .btn{width:100%;justify-content:center}

.note{font-size:.8rem;color:var(--muted);text-align:center;margin-top:.9rem}


/* info side */
.info-card{border:1px solid var(--line);border-radius:var(--r);padding:1.6rem 1.7rem;background:var(--paper);margin-bottom:1.2rem}

.info-card h3{font-size:1.1rem;margin-bottom:1.1rem}

.info-item{display:flex;gap:.9rem;align-items:flex-start;margin-bottom:1.1rem}

.info-item:last-child{margin-bottom:0}

.info-item .ic{flex:none;width:38px;height:38px;border-radius:10px;background:var(--grad-soft);display:grid;place-items:center}

.info-item .lab{font-family:"Sora";font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

.info-item .val{color:var(--ink);font-size:.95rem;font-weight:500}

.info-item .val a:hover{color:var(--blue)}

.map{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;position:relative;background:
  linear-gradient(0deg,rgba(14,18,48,.04),transparent),
  repeating-linear-gradient(0deg,transparent,transparent 26px,var(--paper-2) 26px,var(--paper-2) 27px),
  repeating-linear-gradient(90deg,transparent,transparent 26px,var(--paper-2) 26px,var(--paper-2) 27px),var(--paper)}

.map .pin{position:absolute;top:46%;left:52%;transform:translate(-50%,-100%)}

.map .pin svg{filter:drop-shadow(0 6px 10px rgba(58,111,224,.4))}

.map .label{position:absolute;bottom:14px;left:14px;background:var(--white);border:1px solid var(--line);border-radius:10px;padding:.5rem .8rem;font-size:.82rem;font-weight:600;font-family:"Sora";box-shadow:var(--shadow-sm)}
/* ===== WordPress integration helpers ===== */
header.solid{background:rgba(247,248,250,.92);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.menu li{list-style:none}
.menu .btn{display:inline-flex}
/* WP admin bar offset for sticky header */
body.admin-bar header{top:32px}
@media(max-width:782px){body.admin-bar header{top:46px}}
.menu a.btn-primary{color:#fff}
.menu a.btn-primary:hover{color:#fff}

/* ===== editable page content (prose from block editor) ===== */
.article .wrap{display:block}
.article .prose{max-width:760px;margin:0 auto}
.article .prose > *:first-child{margin-top:0}
.prose table{width:100%;border-collapse:separate;border-spacing:0;background:var(--white);border:1px solid var(--line);border-radius:14px;overflow:hidden;font-size:.92rem;margin:1.6rem 0}
.prose table th,.prose table td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--line)}
.prose table thead th{background:var(--paper-2);font-family:"Sora";font-weight:600;color:var(--ink);font-size:.82rem}
.prose table tbody tr:last-child td{border-bottom:0}
.prose img{border-radius:14px;margin:1.4rem 0}
.prose h2{font-size:clamp(1.5rem,3vw,2.1rem);margin:2.4rem 0 1rem}
.prose h3{font-size:1.2rem;margin:1.8rem 0 .6rem}
.prose blockquote{margin:2rem 0;padding:1.4rem 1.6rem;border-radius:var(--r);background:var(--paper);border-left:3px solid transparent;border-image:var(--grad) 1;font-family:"Sora";font-weight:600;font-size:1.15rem;color:var(--ink)}
.prose blockquote p{color:var(--ink);margin:0}
.prose a{color:var(--blue);text-decoration:underline}
.prose a:hover{color:var(--violet)}

/* ===== compatibility page additions =====
   The page primarily reuses the FAQ layout: .section, .faq-grid, .cats, .faq-col, .faq-cat, .qa, .ans.
*/

.compatibility-page .faq-cat > h2{
  scroll-margin-top:100px;
}

.compatibility-page .qa .ans strong{
  color:var(--ink);
}

.compatibility-page .cta-strip{
  margin-top:2.4rem;
}

.compat-table-scroll{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  margin:.4rem 0 .2rem;
}

.compat-table{
  width:100%;
  min-width:860px;
  border-collapse:separate;
  border-spacing:0;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  font-size:.88rem;
}

.compat-table th,
.compat-table td{
  padding:.8rem .9rem;
  text-align:left;
  vertical-align:top;
  border-bottom:1px solid var(--line);
}

.compat-table thead th{
  background:var(--paper-2);
  font-family:"Sora";
  font-weight:600;
  color:var(--ink);
  font-size:.78rem;
  letter-spacing:.02em;
}

.compat-table tbody tr:last-child td{
  border-bottom:0;
}

.compat-table td:first-child,
.compat-table th:first-child{
  font-weight:600;
  color:var(--ink);
  min-width:210px;
}

@media(max-width:980px){
  .compatibility-page .faq-cat > h2{
    scroll-margin-top:80px;
  }
}

	

/* Long-form TOC template: article headings act like .faq-cat headings */
.faq-col .prose h2{scroll-margin-top:90px;font-size:clamp(1.4rem,2.6vw,1.9rem);margin:2.4rem 0 1.1rem}
.faq-col .prose h2:first-child{margin-top:0}
.faq-col .prose{max-width:760px}
	



.tbl-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbl{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid #e3e6ee;border-radius:14px;overflow:hidden;font-size:.92rem;margin:0 0 1.4rem}
.tbl th,.tbl td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid #e3e6ee}
.tbl thead th{background:#eef0f5;font-family:"Sora",sans-serif;font-weight:600;color:#0E1230;font-size:.82rem;letter-spacing:.02em}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl td:first-child,.tbl th:first-child{font-weight:600;color:#0E1230;width:140px}
.svc{margin-bottom:2.4rem}
.svc h3{font-size:1.25rem;margin-bottom:.4rem;font-family:"Sora",sans-serif;font-weight:700}
.svc>p{color:#6b7088;font-size:.95rem;margin-bottom:1.1rem;max-width:760px}
.services{background:#F7F8FA;border-top:1px solid #e3e6ee}
.sec-head{text-align:center;max-width:750px;margin:0 auto 3rem}
.sec-head h2{font-size:clamp(1.7rem,3.4vw,2.6rem);margin:.6rem 0 .8rem;font-family:"Sora",sans-serif}
.sec-head p{color:#6b7088}
.faq-grid{display:grid;grid-template-columns:220px 1fr;gap:3.5rem;align-items:start}
.cats{position:sticky;top:90px;font-size:.9rem}
.cats h5{font-family:"Sora",sans-serif;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#6b7088;margin-bottom:1rem}
.cats a{display:block;color:#6b7088;padding:.4rem 0 .4rem .9rem;border-left:2px solid #e3e6ee;transition:.15s;text-decoration:none}
.cats a:hover,.cats a.on{color:#0E1230;border-color:#3A6FE0}
.faq-col{max-width:760px}
.faq-cat{margin-bottom:2.8rem}
.faq-cat>h2{font-size:clamp(1.4rem,2.6vw,1.9rem);margin-bottom:1.2rem;scroll-margin-top:90px;font-family:"Sora",sans-serif}
.qa{border:1px solid #e3e6ee;border-radius:14px;margin-bottom:.8rem;background:#fff;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.qa[open]{border-color:rgba(58,111,224,.4);box-shadow:0 2px 10px rgba(14,18,48,.06)}
.qa summary{list-style:none;cursor:pointer;padding:1.1rem 1.3rem;display:flex;align-items:center;gap:1rem;font-family:"Sora",sans-serif;font-weight:600;font-size:1.02rem;color:#0E1230}
.qa summary::-webkit-details-marker{display:none}
.qa summary .ic{margin-left:auto;flex:none;width:24px;height:24px;border-radius:7px;background:linear-gradient(105deg,rgba(31,191,201,.12),rgba(122,51,201,.12));display:grid;place-items:center;transition:transform .25s}
.qa[open] summary .ic{transform:rotate(45deg)}
.qa .ans{padding:0 1.3rem 1.2rem;color:#3a3f5c;font-size:1rem}
.qa .ans ul{margin:.3rem 0 .7rem;padding:0;list-style:none;display:flex;flex-direction:column;gap:.4rem}
.qa .ans li{position:relative;padding-left:1.5rem}
.qa .ans li::before{content:"";position:absolute;left:0;top:.6em;width:7px;height:7px;border-radius:2px;background:linear-gradient(105deg,#1FBFC9,#7A33C9);transform:rotate(45deg)}
.contact-grid{display:grid;grid-template-columns:1fr 360px;gap:3rem;align-items:start}
.form-card{background:#fff;border:1px solid #e3e6ee;border-radius:18px;padding:2rem;box-shadow:0 2px 10px rgba(14,18,48,.06)}
.form-card h2{font-size:1.4rem;margin-bottom:1.4rem;font-family:"Sora",sans-serif}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:"Sora",sans-serif;font-size:.82rem;font-weight:600;color:#0E1230;margin-bottom:.4rem}
.inp{width:100%;padding:.8rem .95rem;border:1px solid #e3e6ee;border-radius:11px;font-family:inherit;font-size:.95rem;color:#0E1230;background:#F7F8FA;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}
.inp:focus{outline:none;border-color:#3A6FE0;box-shadow:0 0 0 3px rgba(58,111,224,.12);background:#fff}
textarea.inp{resize:vertical;min-height:120px}
.radios{display:flex;gap:1.2rem;flex-wrap:wrap;margin-top:.2rem}
.radios label{display:flex;align-items:center;gap:.45rem;font-weight:500;font-size:.92rem;color:#3a3f5c;cursor:pointer}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:#6b7088;margin:.4rem 0 1.3rem}
.info-card{border:1px solid #e3e6ee;border-radius:18px;padding:1.6rem 1.7rem;background:#F7F8FA;margin-bottom:1.2rem}
.info-card h3{font-size:1.1rem;margin-bottom:1.1rem;font-family:"Sora",sans-serif}
.info-item{display:flex;gap:.9rem;align-items:flex-start;margin-bottom:1.1rem}
.info-item .ic{flex:none;width:38px;height:38px;border-radius:10px;background:linear-gradient(105deg,rgba(31,191,201,.12),rgba(122,51,201,.12));display:grid;place-items:center}
.info-item .lab{font-family:"Sora",sans-serif;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#6b7088}
.info-item .val{color:#0E1230;font-size:.95rem;font-weight:500}
@media(max-width:980px){.faq-grid{grid-template-columns:1fr}.cats{display:none}.contact-grid{grid-template-columns:1fr}}
@media(max-width:680px){.row2{grid-template-columns:1fr}}
.section{padding:clamp(48px,7vw,90px) 0}

