/* Secure Origin — shared design system (cybersecurity + hosting) */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --ink:#0d0d0d;
  --ink2:#444;
  --ink3:#777;
  --paper:#f9f7f3;
  --surface:#f2efe9;
  --edge:#e0dbd2;
  --edge2:#ccc8bf;
  --green:#1c3d2b;
  --green2:#2a5a3f;
  --green3:#3d7a57;
  --greenpale:#e6f0ea;
  --greenmid:#c5dccb;
  --amber:#7a4f0d;
  --amberpale:#fdf3e3;
  --red:#8b1e1e;
  --mono:'DM Mono',monospace;
  --sans:'DM Sans',sans-serif;
}

html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);font-size:clamp(15px,0.9vw + 12px,18px);line-height:1.6;-webkit-font-smoothing:antialiased}
.lead{font-size:clamp(16px,1vw + 10px,19px);color:var(--ink2);line-height:1.75;max-width:640px;margin-bottom:20px}

/* NAV */
nav{position:sticky;top:0;z-index:200;background:var(--paper);border-bottom:1px solid var(--edge);height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 5vw}
.logo{display:flex;align-items:center;text-decoration:none}
.logo-img{height:28px;width:auto;display:block}
.nav-r{display:flex;align-items:center;gap:4px}
.nav-r a{font-size:13px;color:var(--ink3);text-decoration:none;padding:6px 12px;border-radius:4px;transition:color .15s,background .15s}
.nav-r a:hover{color:var(--ink);background:var(--surface)}
.nav-r a.here{color:var(--ink);font-weight:500}
.nav-r a.cta{background:var(--green);color:#fff !important;font-weight:500;margin-left:6px}
.nav-r a.cta:hover{background:var(--green2)}

/* ANNOUNCE (hosting) */
.announce{background:var(--green);color:#fff;padding:10px 5vw;display:flex;align-items:center;justify-content:center;gap:10px;font-size:13px;line-height:1.5;text-align:center}
.announce-icon{flex-shrink:0;opacity:.5;color:#fff}

/* HERO */
.hero{padding:80px 5vw 64px;max-width:1120px;margin:0 auto;display:block}
.page-hosting .hero{display:block;max-width:1120px}
.eyebrow{font-family:var(--mono);font-size:clamp(11px,0.6vw + 7px,13px);letter-spacing:.15em;color:var(--green3);text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.eyebrow::before{content:'';width:20px;height:1px;background:var(--green3)}
h1{font-size:clamp(30px,4vw,48px);font-weight:600;letter-spacing:-.025em;line-height:1.1;margin-bottom:22px}
.page-hosting .hero h1{font-size:clamp(32px,4.5vw,52px)}
.hero-sub{font-size:clamp(16px,1vw + 10px,19px);color:var(--ink2);line-height:1.75;margin-bottom:32px}
.page-hosting .hero-sub{margin-bottom:36px}
.hero-acts{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:7px;padding:11px 22px;border-radius:4px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green2)}
.btn-outline{border:1px solid var(--edge2);color:var(--ink);background:transparent}
.btn-outline:hover{border-color:#999;background:var(--surface)}

/* HERO STATS (cybersecurity) */
.hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding-top:8px}
.stat-card{background:var(--surface);border:1px solid var(--edge);border-radius:8px;padding:22px 20px}
.stat-num{font-family:var(--mono);font-size:28px;font-weight:500;color:var(--ink);line-height:1;margin-bottom:6px}
.stat-label{font-size:13px;color:var(--ink2);line-height:1.5}
.stat-card.dark-card{background:var(--ink);border-color:var(--ink)}
.stat-card.dark-card .stat-num{color:#fff}
.stat-card.dark-card .stat-label{color:#888}

/* Horizontal stat strip */
.stat-strip{display:flex;justify-content:center;gap:0;background:var(--ink);padding:28px 5vw;flex-wrap:wrap}
.stat-item{text-align:center;padding:0 clamp(20px,3vw,48px);border-right:1px solid rgba(255,255,255,.12)}
.stat-item:last-child{border-right:none}
.stat-item .stat-num{font-family:var(--mono);font-size:clamp(22px,1.6vw,30px);font-weight:500;color:#fff;line-height:1;margin-bottom:6px}
.stat-item .stat-label{font-size:clamp(11px,0.7vw,13px);color:rgba(255,255,255,.5);line-height:1.5;white-space:nowrap}

.page-hosting .hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px}
.tag{font-family:var(--mono);font-size:11px;letter-spacing:.05em;padding:5px 11px;border-radius:3px;border:1px solid var(--edge2);color:var(--ink3)}
.tag.green{background:var(--greenpale);border-color:var(--greenmid);color:var(--green)}

/* TRUST */
.trustbar{background:var(--surface);border-top:1px solid var(--edge);border-bottom:1px solid var(--edge);padding:14px 5vw;display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.ti{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--ink3)}
.ti strong{color:var(--ink);font-weight:500}
.sep{width:3px;height:3px;border-radius:50%;background:var(--edge2)}

/* SECTION */
.sec{padding:72px 5vw}
.sec-inner{max-width:1120px;margin:0 auto}
.sec-label{font-family:var(--mono);font-size:clamp(11px,0.6vw + 7px,13px);letter-spacing:.14em;color:var(--ink3);text-transform:uppercase;margin-bottom:14px}
h2{font-size:clamp(22px,3vw,34px);font-weight:600;letter-spacing:-.02em;line-height:1.2;margin-bottom:14px}
.sec-sub{font-size:clamp(15px,0.9vw + 10px,18px);color:var(--ink2);line-height:1.7;max-width:540px;margin-bottom:48px}
hr{border:none;border-top:1px solid var(--edge)}

/* SERVICES (cybersecurity) */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--edge);border:1px solid var(--edge);border-radius:8px;overflow:hidden}
.svc-card{background:var(--paper);padding:32px 26px;transition:background .15s;color:inherit}
a.svc-card{cursor:pointer;text-decoration:none;color:inherit;display:block}
a.svc-card:hover{background:var(--surface)}
article.svc-card{display:flex;flex-direction:column;min-height:100%;cursor:default;border:none;margin:0}
article.svc-card:hover{background:var(--surface)}
.svc-icon{width:36px;height:36px;border-radius:6px;background:var(--greenpale);border:1px solid var(--greenmid);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.svc-name{font-size:16px;font-weight:600;margin-bottom:8px}
.svc-desc{font-size:clamp(13px,0.8vw + 9px,15px);color:var(--ink2);line-height:1.65;margin-bottom:16px;flex:1}
.svc-detail{font-size:13px;color:var(--ink3);line-height:1.6}
.svc-link{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:500;color:var(--green3);margin-top:16px}
.svc-details-btn{border:none;background:none;padding:0;margin:0;font:inherit;text-align:left;cursor:pointer;display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:500;color:var(--green3);margin-top:16px}
.svc-details-btn:hover{text-decoration:underline}

/* Service detail tray (native dialog) */
.service-tray{border:none;border-radius:12px;padding:0;max-width:min(720px,calc(100vw - 32px));width:100%;max-height:min(90vh,900px);background:var(--paper);color:var(--ink);box-shadow:0 24px 64px rgba(0,0,0,.28);position:fixed;inset:0;margin:auto}
.service-tray::backdrop{background:rgba(0,0,0,.45)}
.service-tray-inner{padding:28px 28px 24px;overflow:auto;max-height:min(90vh,900px);position:relative}
.service-tray-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border:none;border-radius:8px;background:var(--surface);color:var(--ink);font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.service-tray-close:hover{background:var(--edge)}
.service-tray .eyebrow{margin-bottom:8px}
.service-tray h2{font-size:clamp(20px,2.8vw,28px);margin-bottom:12px;padding-right:44px}
.service-tray-lead{margin-bottom:8px}
.service-tray-foot{margin-top:28px;padding-top:20px;border-top:1px solid var(--edge)}

/* APPROACH (cybersecurity) */
.approach-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.approach-left h2{margin-bottom:16px}
.approach-left p{font-size:16px;color:var(--ink2);line-height:1.75;margin-bottom:14px}
.approach-left p strong{color:var(--ink);font-weight:500}
.approach-right{display:flex;flex-direction:column;gap:16px}
.approach-step{border:1px solid var(--edge);border-radius:8px;padding:22px 24px;display:flex;gap:18px;align-items:flex-start}
.step-num{font-family:var(--mono);font-size:20px;font-weight:500;color:var(--edge2);line-height:1;flex-shrink:0;padding-top:2px}
.step-title{font-size:15px;font-weight:600;margin-bottom:5px}
.step-desc{font-size:13px;color:var(--ink2);line-height:1.6}

/* WHO */
.who-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--edge);border:1px solid var(--edge);border-radius:8px;overflow:hidden}
.who-card{background:var(--paper);padding:28px 24px}
.page-hosting .who-card{padding:30px 26px}
.who-icon{width:36px;height:36px;border-radius:6px;background:var(--greenpale);border:1px solid var(--greenmid);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.who-title{font-size:15px;font-weight:600;margin-bottom:8px}
.who-desc{font-size:clamp(13px,0.8vw + 9px,15px);color:var(--ink2);line-height:1.65;margin-bottom:12px}
.page-hosting .who-desc{margin-bottom:14px}
.who-eg{font-family:var(--mono);font-size:11px;color:var(--ink3);letter-spacing:.03em}

/* DARK — validation compare (cybersecurity) */
.dark{background:var(--ink);color:#fff;padding:72px 5vw}
.dark .sec-label{color:#555}
.dark h2{color:#fff}
.dark .sec-sub{color:#777;max-width:640px}
.val-compare{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:40px}
.vc{border-radius:8px;padding:24px}
.vc-bad{background:#180f0f;border:1px solid #3a1a1a}
.vc-good{background:#0a1a12;border:1px solid #1a3a28}
.vc-label{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:7px}
.vc-bad .vc-label{color:#8b3a3a}
.vc-good .vc-label{color:#3a8b5a}
.vc-title{font-size:14px;font-weight:600;color:#fff;margin-bottom:10px}
.vc-list{list-style:none}
.vc-list li{font-size:13px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04);display:flex;align-items:flex-start;gap:8px;color:#888;line-height:1.5}
.vc-list li:last-child{border-bottom:none}
.bdot{width:5px;height:5px;border-radius:50%;background:#8b3a3a;flex-shrink:0;margin-top:5px}
.gdot{width:5px;height:5px;border-radius:50%;background:#3a8b5a;flex-shrink:0;margin-top:5px}

/* DARK — hosting comparison */
.cmp-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.cmp{border-radius:8px;padding:28px}
.cmp-bad{background:#180f0f;border:1px solid #3a1a1a}
.cmp-good{background:#0a1a12;border:1px solid #1a3a28}
.cmp-lbl{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.cmp-bad .cmp-lbl{color:#8b3a3a}
.cmp-good .cmp-lbl{color:#3a8b5a}
.cmp-title{font-size:15px;font-weight:600;color:#fff;margin-bottom:14px}
.cmp-list{list-style:none}
.cmp-list li{font-size:13px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:flex-start;gap:9px;color:#888;line-height:1.5}
.cmp-list li:last-child{border-bottom:none}

/* TESTIMONIALS (cybersecurity grid) */
.testi-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:0}
.testi-card{border:1px solid var(--edge);border-radius:8px;padding:32px 28px}
.testi-logo{height:22px;opacity:.55;filter:grayscale(100%);margin-bottom:24px}
.testi-quote{font-size:clamp(14px,0.8vw + 9px,17px);font-weight:300;line-height:1.75;color:#222;margin-bottom:18px;font-style:italic}
.testi-attr{font-size:13px;color:var(--ink3)}
.testi-attr strong{color:var(--ink);font-weight:500}

/* APPS (hosting) */
.apps-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.app-card{border:1px solid var(--edge);border-radius:8px;padding:26px;display:flex;gap:18px;align-items:flex-start;transition:border-color .15s}
.app-card:hover{border-color:var(--edge2)}
.app-icon{width:42px;height:42px;border-radius:8px;background:var(--surface);border:1px solid var(--edge);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--mono);font-size:11px;font-weight:500;color:var(--ink3)}
.app-name{font-size:15px;font-weight:600;margin-bottom:3px}
.app-replaces{font-family:var(--mono);font-size:11px;color:var(--ink3);margin-bottom:8px;letter-spacing:.03em}
.app-desc{font-size:13px;color:var(--ink2);line-height:1.65}
.app-note{font-size:12px;color:var(--amber);margin-top:8px;line-height:1.5}
.tier-pill{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.06em;padding:3px 8px;border-radius:3px;margin-top:10px}
.tp-all{background:var(--greenpale);color:var(--green);border:1px solid var(--greenmid)}
.tp-mid{background:var(--amberpale);color:var(--amber);border:1px solid #e6cfa0}
.tp-bes{background:#f5e8fb;color:#4a1a6b;border:1px solid #d9b8ea}

/* REFER */
.refer-row{display:flex;align-items:flex-start;gap:16px;padding:16px 0;border-bottom:1px solid var(--surface)}
.refer-row:last-child{border-bottom:none}
.refer-name{font-size:14px;font-weight:500;min-width:140px;color:var(--ink)}
.refer-desc{font-size:14px;color:var(--ink2);line-height:1.6}
.refer-wrap{border:1px solid var(--edge);border-radius:8px;padding:8px 20px}

/* PLANS */
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.plan-card{border:1px solid var(--edge);border-radius:8px;padding:32px 28px;position:relative;transition:border-color .15s}
.plan-card.featured{border:2px solid var(--green)}
.plan-badge{position:absolute;top:-11px;left:24px;background:var(--green);color:#fff;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:3px}
.plan-label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:10px}
.plan-name{font-size:20px;font-weight:600;margin-bottom:6px}
.plan-desc{font-size:13px;color:var(--ink2);line-height:1.6;margin-bottom:20px;min-height:56px}
.plan-price{font-size:30px;font-weight:600;letter-spacing:-.02em;margin-bottom:3px}
.plan-price sup{font-size:16px;font-weight:400;vertical-align:super}
.plan-price sub{font-size:14px;font-weight:400;color:var(--ink3)}
.plan-from{font-size:12px;color:var(--ink3);margin-bottom:24px}
.plan-feats{list-style:none;margin-bottom:28px}
.plan-feats li{font-size:13px;padding:7px 0;border-bottom:1px solid var(--surface);display:flex;align-items:flex-start;gap:9px;color:var(--ink2);line-height:1.5}
.plan-feats li:last-child{border-bottom:none}
.fcheck{width:15px;height:15px;border-radius:50%;background:var(--greenpale);border:1px solid var(--greenmid);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.fcheck::after{content:'';width:5px;height:3px;border-left:1.4px solid var(--green);border-bottom:1.4px solid var(--green);transform:rotate(-45deg) translateY(-1px);display:block}
.plan-cta{display:block;text-align:center;padding:10px;border-radius:4px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s}
.plan-cta.p{background:var(--green);color:#fff}
.plan-cta.p:hover{background:var(--green2)}
.plan-cta.g{border:1px solid var(--edge2);color:var(--ink)}
.plan-cta.g:hover{border-color:#999;background:var(--surface)}

/* APP MATRIX */
.matrix-wrap{border:1px solid var(--edge);border-radius:8px;overflow:hidden;margin-top:40px}
.mx-head{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;background:var(--surface);border-bottom:1px solid var(--edge);padding:12px 20px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3)}
.mx-head span:not(:first-child){text-align:center}
.mx-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;padding:13px 20px;border-bottom:1px solid var(--surface);align-items:center}
.mx-row:last-child{border-bottom:none}
.mx-row:hover{background:var(--surface)}
.mx-row span:not(:first-child){display:flex;justify-content:center}
.rn{font-size:13px;font-weight:500}
.rs{font-size:11px;color:var(--ink3);margin-top:1px}
.mck{width:18px;height:18px;border-radius:50%;background:var(--greenpale);border:1px solid var(--greenmid);display:flex;align-items:center;justify-content:center}
.mck::after{content:'';width:6px;height:4px;border-left:1.5px solid var(--green);border-bottom:1.5px solid var(--green);transform:rotate(-45deg) translateY(-1px);display:block}
.mno{width:18px;height:18px;border-radius:50%;background:var(--surface);border:1px solid var(--edge);display:flex;align-items:center;justify-content:center}
.mno::after{content:'';width:8px;height:1px;background:var(--edge2);display:block}
.madd{font-family:var(--mono);font-size:10px;color:var(--amber);padding:2px 6px;border:1px solid #e6cfa0;border-radius:3px;background:var(--amberpale);white-space:nowrap}

/* PROCESS */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--edge);border-radius:8px;overflow:hidden}
.proc-step{padding:28px 22px;border-right:1px solid var(--edge)}
.proc-step:last-child{border-right:none}
.proc-num{font-family:var(--mono);font-size:26px;font-weight:500;color:var(--edge2);line-height:1;margin-bottom:14px}
.proc-title{font-size:14px;font-weight:600;margin-bottom:8px}
.proc-desc{font-size:13px;color:var(--ink2);line-height:1.6}

/* TESTI single (hosting) */
.testi{background:var(--surface);padding:64px 5vw;border-top:1px solid var(--edge);border-bottom:1px solid var(--edge)}
.testi-inner{max-width:740px;margin:0 auto;text-align:center}
.testi .testi-logo{height:24px;margin:0 auto 30px;display:block}
.testi blockquote{font-size:clamp(16px,2vw,19px);font-weight:300;line-height:1.75;color:#222;margin-bottom:22px;font-style:italic}
.testi cite{font-size:13px;color:var(--ink3);font-style:normal}
.testi cite strong{color:var(--ink);font-weight:500}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:5fr 7fr;gap:64px;align-items:start}
.contact-left h2{margin-bottom:14px}
.contact-left p{font-size:clamp(14px,0.8vw + 9px,17px);color:var(--ink2);line-height:1.7;margin-bottom:24px}
.cd{display:flex;align-items:flex-start;gap:11px;margin-bottom:14px;font-size:14px;color:var(--ink2);line-height:1.5}
.cd-icon{width:27px;height:27px;border-radius:5px;background:var(--greenpale);border:1px solid var(--greenmid);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.cform{background:var(--surface);border:1px solid var(--edge);border-radius:8px;padding:30px}
.fg{margin-bottom:16px}
label{display:block;font-size:12px;font-weight:500;color:var(--ink2);margin-bottom:5px}
input,select,textarea{width:100%;padding:9px 12px;border:1px solid var(--edge2);border-radius:4px;font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--paper);outline:none;transition:border-color .15s}
input:focus,select:focus,textarea:focus{border-color:var(--green3)}
textarea{resize:vertical;min-height:88px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sbtn{width:100%;padding:11px;background:var(--green);color:#fff;border:none;border-radius:4px;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;margin-top:4px}
.sbtn:hover{background:var(--green2)}
.fnote{font-size:11px;color:var(--ink3);margin-top:10px;text-align:center;line-height:1.5}

/* FOOTER */
.site-footer{background:var(--ink);color:rgba(255,255,255,.55);padding:56px 5vw 0}
.footer-inner{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;padding-bottom:40px}
.footer-brand{max-width:340px}
.footer-logo{display:inline-block;margin-bottom:16px}
.footer-logo .logo-img{height:24px;filter:brightness(0) invert(1)}
.footer-tagline{font-size:14px;line-height:1.65;color:rgba(255,255,255,.5);margin:0}
.footer-col{display:flex;flex-direction:column;gap:8px}
.footer-col a{font-size:14px;color:rgba(255,255,255,.55);text-decoration:none;transition:color .15s}
.footer-col a:hover{color:#fff}
.footer-col p{font-size:14px;line-height:1.6;margin:0}
.footer-heading{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:8px}
.footer-bottom{max-width:1120px;margin:0 auto;border-top:1px solid rgba(255,255,255,.08);padding:20px 0;text-align:center}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.3);margin:0}
.footer-tm{font-size:11px;color:rgba(255,255,255,.2);margin-top:8px}

/* CROSSLINK */
.xlink{background:var(--green);padding:48px 5vw;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap}
.xl-l h3{font-size:19px;font-weight:600;color:#fff;margin-bottom:6px}
.xl-l p{font-size:14px;color:rgba(255,255,255,.65);max-width:500px;line-height:1.6}
.btn-white{background:#fff;color:var(--green);padding:11px 22px;border-radius:4px;font-size:14px;font-weight:600;text-decoration:none;display:inline-block;transition:opacity .15s;white-space:nowrap}
.btn-white:hover{opacity:.9}

@media(max-width:900px){
  .hero{display:block}
  .svc-grid,.who-grid,.plans-grid{grid-template-columns:1fr}
  .approach-grid,.val-compare,.testi-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .cmp-grid{grid-template-columns:1fr}
  .apps-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr 1fr}
  .proc-step:nth-child(2){border-right:none}
  .proc-step:nth-child(3){border-top:1px solid var(--edge)}
  .mx-head,.mx-row{grid-template-columns:1fr 44px 44px 44px}
  .nav-r a:not(.cta){display:none}
  .xlink{flex-direction:column}
  .pillars-grid{grid-template-columns:1fr}
  .about-profile{grid-template-columns:1fr;text-align:center}
  .about-avatar{margin:0 auto}
  .footer-inner{grid-template-columns:1fr;gap:32px}
}

@media(max-width:600px){
  .hero-stats{grid-template-columns:1fr 1fr}
  .stat-strip{flex-wrap:wrap;gap:20px 0;padding:20px 5vw}
  .stat-item{flex:1 0 50%;padding:8px 0;border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
  .stat-item:nth-last-child(-n+2){border-bottom:none}
  .fg-row{grid-template-columns:1fr}
  .trustbar{gap:16px}
  .proc-grid{grid-template-columns:1fr}
  .proc-step{border-right:none !important;border-top:1px solid var(--edge)}
  .proc-step:first-child{border-top:none}
  .plan-desc{min-height:auto}
}

@media(min-width:1600px){
  body{font-size:18px}
  h1{font-size:52px}
  h2{font-size:36px}
  .hero-sub,.lead,.sec-sub{font-size:19px}
  .svc-desc,.who-desc,.pillar-card p,.faq-body{font-size:16px}
  .svc-name,.who-title,.pillar-card h3{font-size:17px}
  .testi-quote,.contact-left p{font-size:17px}
  .service-prose p,.about-bio p{font-size:18px}
  nav{height:68px}
  .logo-img{height:32px}
}

/* Live-style approach pillars (3-up) */
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--edge);border:1px solid var(--edge);border-radius:8px;overflow:hidden}
.pillar-card{background:var(--paper);padding:28px 24px}
.pillar-card h3{font-size:15px;font-weight:600;margin-bottom:10px;color:var(--ink)}
.pillar-card p{font-size:clamp(13px,0.8vw + 9px,15px);color:var(--ink2);line-height:1.65;margin:0}
.dark .pillars-grid{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.1);grid-template-columns:repeat(2,1fr)}
.dark .pillar-card{background:rgba(255,255,255,.06)}
.dark .pillar-card h3{color:#fff}
.dark .pillar-card p{color:rgba(255,255,255,.6)}

/* Blog */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.blog-card{background:var(--surface);border:1px solid var(--edge);border-radius:8px;padding:32px 28px;text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:background .15s,border-color .15s}
.blog-card:hover{background:var(--paper);border-color:var(--edge2)}
.blog-tag{font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--green3);text-transform:uppercase;margin-bottom:12px}
.blog-card h3{font-size:clamp(17px,1.1vw + 10px,20px);font-weight:600;color:var(--ink);line-height:1.4;margin-bottom:12px}
.blog-card p{font-size:clamp(13px,0.8vw + 9px,15px);color:var(--ink2);line-height:1.65;flex:1}
.blog-meta{font-family:var(--mono);font-size:11px;color:var(--ink3);margin-top:16px;letter-spacing:.03em}
.blog-post{max-width:720px}
.blog-post h2{font-size:clamp(20px,1.5vw + 12px,26px);font-weight:600;margin-top:40px;margin-bottom:16px;color:var(--ink)}
.blog-post h3{font-size:clamp(16px,1vw + 10px,19px);font-weight:600;margin-top:32px;margin-bottom:12px;color:var(--ink)}
.blog-post p{font-size:clamp(15px,0.9vw + 10px,17px);color:var(--ink2);line-height:1.8;margin-bottom:20px}
.blog-post ul,.blog-post ol{font-size:clamp(15px,0.9vw + 10px,17px);color:var(--ink2);line-height:1.8;margin-bottom:20px;padding-left:24px}
.blog-post li{margin-bottom:8px}
.blog-post blockquote{border-left:3px solid var(--green3);padding:16px 24px;margin:28px 0;background:var(--surface);border-radius:0 6px 6px 0}
.blog-post blockquote p{color:var(--ink);font-style:italic;margin-bottom:0}
.blog-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--green3);text-decoration:none;margin-bottom:32px}
.blog-back:hover{text-decoration:underline}

/* About — profile + FAQ */
.page-about .hero{max-width:1120px;margin:0 auto;padding:72px 5vw 48px;display:block}
.about-profile{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:start;margin-top:8px}
.about-avatar{width:112px;height:112px;border-radius:50%;background:var(--greenpale);border:1px solid var(--greenmid);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:26px;font-weight:500;color:var(--green3);flex-shrink:0}
img.about-photo{width:112px;height:112px;border-radius:50%;object-fit:cover;border:1px solid var(--greenmid);flex-shrink:0;display:block}

/* Service detail subpages */
.detail-back{margin-bottom:20px}
.detail-back a{font-size:14px;font-weight:500;color:var(--green3);text-decoration:none}
.detail-back a:hover{text-decoration:underline}
.service-prose{max-width:720px;margin-top:8px}
.service-prose p{font-size:clamp(15px,0.9vw + 10px,18px);color:var(--ink2);line-height:1.75;margin-bottom:16px}
.service-prose ul{margin:12px 0 20px 1.2em;color:var(--ink2);line-height:1.7}
.service-prose li{margin-bottom:8px}
.service-prose strong{color:var(--ink)}
.about-role{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--green3);text-transform:uppercase;margin-bottom:8px}
.about-bio p{font-size:clamp(15px,0.9vw + 10px,18px);color:var(--ink2);line-height:1.75;margin-bottom:14px}
.about-bio p:last-child{margin-bottom:0}
.faq-wrap{margin-top:8px}
.faq-list{border:1px solid var(--edge);border-radius:8px;overflow:hidden;margin-top:20px}
.faq-item{border-bottom:1px solid var(--edge)}
.faq-item:last-child{border-bottom:none}
.faq-item summary{cursor:pointer;padding:16px 20px;font-weight:500;font-size:15px;list-style:none;background:var(--paper)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item[open] summary{background:var(--surface)}
.faq-body{padding:0 20px 18px;font-size:clamp(13px,0.8vw + 9px,15px);color:var(--ink2);line-height:1.65}
