/*
Theme Name: Ember Studio
Theme URI: https://example.com/ember-studio
Author: Ember Studio
Description: A bold black-and-yellow one-page theme for design agencies and studios. Built for speed: hero, work grid, dynamic services, pricing, testimonials, FAQ, and a working contact form (sends to your WordPress admin email). Fully mobile responsive.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
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: ember-studio
Tags: one-column, custom-menu, custom-logo, full-width-template, portfolio
*/

:root{
  --ink:#0A0A0A;
  --ink-2:#121212;
  --ink-3:#1B1B1B;
  --paper:#F7F6F2;
  --paper-dim:#ABABA4;
  --yellow:#FFE100;
  --yellow-soft:#FFF06B;
  --line:rgba(247,246,242,.12);
  --line-strong:rgba(247,246,242,.24);
  --radius:18px;
  --font:'Outfit',system-ui,sans-serif;
  --max:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--paper);font-family:var(--font);font-size:17px;font-weight:450;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.es-section{padding:104px 0;position:relative;scroll-margin-top:90px}
.skip{position:absolute;left:-999px;top:0;background:var(--yellow);color:var(--ink);font-weight:700;padding:12px 18px;z-index:200;border-radius:0 0 12px 0}
.skip:focus{left:0}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--yellow);display:flex;align-items:center;gap:10px;margin-bottom:22px}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--yellow)}
h2.sec-title{font-weight:800;font-size:clamp(38px,5.4vw,68px);line-height:1.04;letter-spacing:-0.015em}
.sec-sub{max-width:580px;color:var(--paper-dim);margin-top:18px;font-size:18px;font-weight:500}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:56px;flex-wrap:wrap}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:16px 28px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:transform .25s cubic-bezier(.2,.8,.2,1),background .25s,color .25s,border-color .25s;white-space:nowrap;font-family:var(--font)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}
.btn:hover{transform:translateY(-2px)}
.btn-yellow{background:var(--yellow);color:var(--ink)}
.btn-yellow:hover{background:#fff04d}
.btn-ghost{border-color:var(--line-strong);color:var(--paper)}
.btn-ghost:hover{border-color:var(--yellow);color:var(--yellow)}

/* nav */
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;transition:background .3s,border-color .3s;border-bottom:1px solid transparent}
.admin-bar .site-header{top:32px}
@media(max-width:782px){.admin-bar .site-header{top:46px}}
.site-header.scrolled{background:rgba(10,10,10,.88);backdrop-filter:blur(14px);border-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;max-width:var(--max);margin:0 auto;padding:0 24px}
.logo{font-weight:900;font-size:23px;letter-spacing:.02em;display:flex;align-items:center;gap:10px}
.logo .dot{width:12px;height:12px;border-radius:50%;background:var(--yellow);box-shadow:0 0 18px var(--yellow);animation:pulse 2.4s infinite}
.logo img{max-height:38px;width:auto}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.78);opacity:.7}}
.nav-links{display:flex;gap:4px;align-items:center;list-style:none}
.nav-links a{font-size:13.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:10px 15px;border-radius:999px;color:var(--paper-dim);transition:color .2s,background .2s;display:inline-block}
.nav-links a:hover{color:var(--paper);background:rgba(255,255,255,.05)}
.nav-cta{display:flex;gap:10px;align-items:center}
.burger{display:none;background:none;border:1px solid var(--line-strong);border-radius:999px;color:var(--paper);padding:12px 18px;font-family:var(--font);font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer}
.mobile-menu{display:none;flex-direction:column;gap:4px;padding:12px 24px 28px;background:rgba(10,10,10,.97);border-bottom:1px solid var(--line);list-style:none;max-width:100vw;overflow-x:hidden}
.mobile-menu a{font-size:15px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:15px 4px;border-bottom:1px solid var(--line);color:var(--paper-dim);display:block}
.mobile-menu.open{display:flex}

/* hero */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;padding:150px 0 0;overflow:hidden;position:relative}
.hero-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(900px 500px at 80% 0%,rgba(255,225,0,.10),transparent 60%),radial-gradient(700px 500px at 10% 90%,rgba(255,225,0,.05),transparent 60%)}
.hero-top{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.hero-tags{display:flex;gap:8px;flex-wrap:wrap}
.tag{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line-strong);border-radius:999px;padding:9px 15px;color:var(--paper-dim);transition:border-color .2s,color .2s}
.tag:hover{border-color:var(--yellow);color:var(--yellow)}
.avail{display:inline-flex;align-items:center;gap:9px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border:1px solid rgba(255,225,0,.4);background:rgba(255,225,0,.07);border-radius:999px;padding:9px 16px;color:var(--yellow)}
.avail .live{width:8px;height:8px;border-radius:50%;background:var(--yellow);animation:pulse 1.8s infinite}
.hero-title{font-weight:900;text-transform:uppercase;line-height:.95;letter-spacing:-0.02em;font-size:clamp(58px,12.5vw,180px);margin:48px 0 0}
.hero-title .row{display:flex;align-items:center;gap:.16em;flex-wrap:wrap}
.hero-title .hollow{color:transparent;-webkit-text-stroke:2.5px var(--paper)}
.hero-title .yellow-word{color:var(--yellow)}
.hero-48{display:inline-flex;align-items:center;justify-content:center;background:var(--yellow);color:var(--ink);border-radius:.16em;padding:0 .12em;transform:rotate(-2deg);box-shadow:0 18px 60px rgba(255,225,0,.28);animation:tilt 5s ease-in-out infinite}
@keyframes tilt{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(1.2deg)}}
.hero-bottom{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:end;margin:56px 0 64px}
.hero-copy{color:var(--paper-dim);font-size:19px;font-weight:500;max-width:580px}
.hero-copy strong{color:var(--paper);font-weight:700}
.hero-actions{display:flex;flex-direction:column;align-items:flex-end;gap:16px}
.hero-actions .row{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.hero-fine{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-dim)}
.hero-fine b{color:var(--yellow)}

/* stats */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink-2)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:38px 28px;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat .num{font-weight:800;font-size:clamp(34px,4vw,52px);line-height:1;letter-spacing:-0.01em}
.stat .num span{color:var(--yellow)}
.stat .lbl{font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--paper-dim);margin-top:10px}

/* ticker */
.ticker-wrap{border-bottom:1px solid var(--line);background:var(--ink)}
.ticker-label{text-align:center;font-size:11.5px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--paper-dim);padding:26px 24px 0}
.ticker{overflow:hidden;padding:20px 0 28px}
.ticker-track{display:flex;gap:64px;width:max-content;animation:scroll 28s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-item{font-weight:800;font-size:21px;letter-spacing:.04em;text-transform:uppercase;color:var(--paper-dim);display:flex;align-items:center;gap:64px;white-space:nowrap}
.ticker-item::after{content:"✦";color:var(--yellow);font-size:15px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* work */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.work-card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--ink-2);transition:transform .45s cubic-bezier(.17,.67,.12,.99),border-color .45s, box-shadow .45s;display:block;position:relative}
.work-card:hover{transform:translateY(-8px) scale(1.01);border-color:var(--yellow);box-shadow:0 25px 70px rgba(255,225,0,.12)}
.work-thumb{aspect-ratio:16/10;position:relative;overflow:hidden;background:var(--ink-3)}
.work-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.8,.2,1);filter:saturate(.9)}
.work-card:hover .work-thumb img{transform:scale(1.06)}
.work-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.25),transparent 40%,rgba(10,10,10,.35))}
.work-pill{position:absolute;top:16px;left:16px;z-index:2;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;background:rgba(10,10,10,.75);backdrop-filter:blur(6px);border:1px solid var(--line-strong);border-radius:999px;padding:8px 13px}
.work-pill b{color:var(--yellow);font-weight:800}
.work-info{display:flex;justify-content:space-between;align-items:center;padding:20px 22px;gap:14px}
.work-name{font-weight:800;font-size:21px}
.work-cats{display:flex;gap:8px;flex-shrink:0}
.work-cats span{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line-strong);border-radius:999px;padding:6px 11px;color:var(--paper-dim)}

/* services */
.svc{border-top:1px solid var(--line);position:relative}
.svc-row{display:grid;grid-template-columns:64px 1.1fr 1.5fr auto auto auto;align-items:center;gap:26px;padding:32px 14px;border-bottom:1px solid var(--line);position:relative;overflow:hidden;cursor:pointer;transition:padding .35s cubic-bezier(.2,.8,.2,1)}
.svc-row::before{content:"";position:absolute;inset:0;background:var(--yellow);transform:translateY(101%);transition:transform .4s cubic-bezier(.2,.8,.2,1);z-index:0}
.svc-row:hover::before{transform:translateY(0)}
.svc-row>*{position:relative;z-index:1;transition:color .3s}
.svc-row:hover{padding-left:26px}
.svc-row:hover .svc-num,.svc-row:hover .svc-name,.svc-row:hover .svc-desc,.svc-row:hover .svc-price{color:var(--ink)}
.svc-num{font-size:13.5px;font-weight:700;color:var(--paper-dim)}
.svc-name{font-weight:800;font-size:clamp(22px,2.8vw,32px);letter-spacing:-0.01em}
.svc-desc{color:var(--paper-dim);font-size:15px;font-weight:500;max-width:460px}
.svc-price{font-size:14px;font-weight:700;letter-spacing:.06em;color:var(--paper)}
.svc-ship{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:rgba(255,225,0,.1);color:var(--yellow);border:1px solid rgba(255,225,0,.45);border-radius:999px;padding:8px 14px;white-space:nowrap;transition:all .3s}
.svc-row:hover .svc-ship{background:var(--ink);border-color:var(--ink);color:var(--yellow)}
.svc-go{width:44px;height:44px;border-radius:50%;border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .35s}
.svc-row:hover .svc-go{background:var(--ink);border-color:var(--ink);color:var(--yellow);transform:rotate(-45deg)}
.svc-preview{position:fixed;width:260px;aspect-ratio:4/3;border-radius:14px;overflow:hidden;pointer-events:none;z-index:90;opacity:0;transform:scale(.85) rotate(-3deg);transition:opacity .25s,transform .25s;box-shadow:0 30px 80px rgba(0,0,0,.55);border:1px solid var(--line-strong)}
.svc-preview.show{opacity:1;transform:scale(1) rotate(-3deg)}
.svc-preview img{width:100%;height:100%;object-fit:cover}

/* arch cards */
.arch-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.arch-card{border:1px solid var(--line);border-radius:var(--radius);padding:38px 34px;background:linear-gradient(180deg,var(--ink-2),var(--ink));position:relative;overflow:hidden;transition:border-color .3s,transform .3s}
.arch-card:hover{border-color:rgba(255,225,0,.45);transform:translateY(-4px)}
.arch-card .idx{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--yellow)}
.arch-card h3{font-weight:800;font-size:25px;letter-spacing:-0.01em;margin:16px 0 12px}
.arch-card p{color:var(--paper-dim);font-size:15.5px;font-weight:500;max-width:430px}
.arch-card .glyph{position:absolute;right:-14px;bottom:-28px;font-weight:900;font-size:130px;color:rgba(255,225,0,.06);line-height:1;pointer-events:none}

/* sprint */
.sprint{background:var(--yellow);color:var(--ink);border-top:1px solid var(--line)}
.sprint .eyebrow{color:var(--ink)}
.sprint .eyebrow::before{background:var(--ink)}
.sprint-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:56px;align-items:center}
.sprint h2{font-weight:900;font-size:clamp(48px,7.6vw,104px);line-height:.96;text-transform:uppercase;letter-spacing:-0.02em}
.sprint h2 .out{color:transparent;-webkit-text-stroke:2.5px var(--ink)}
.sprint p{margin-top:22px;font-size:18px;max-width:520px;color:rgba(10,10,10,.78);font-weight:600}
.sprint-card{background:var(--ink);color:var(--paper);border-radius:var(--radius);padding:36px;box-shadow:0 30px 80px rgba(10,10,10,.35)}
.sprint-card h3{font-weight:800;font-size:24px;margin-bottom:22px}
.spec{display:flex;justify-content:space-between;font-size:14.5px;font-weight:600;letter-spacing:.04em;padding:14px 0;border-bottom:1px solid var(--line)}
.spec .k{color:var(--paper-dim)}
.spec .v{color:var(--yellow);font-weight:700}
.sprint-card .btn{margin-top:26px;width:100%;justify-content:center}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.plan{border:1px solid var(--line);border-radius:var(--radius);padding:36px 30px;background:var(--ink-2);display:flex;flex-direction:column;transition:transform .3s,border-color .3s;position:relative}
.plan:hover{transform:translateY(-6px)}
.plan.pop{border-color:var(--yellow);background:linear-gradient(180deg,rgba(255,225,0,.08),var(--ink-2) 45%)}
.plan .badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--yellow);color:var(--ink);font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:7px 15px;border-radius:999px}
.plan .tier{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-dim)}
.plan h3{font-weight:800;font-size:28px;margin:10px 0 6px}
.plan .amt{font-weight:800;font-size:44px;margin:14px 0 4px;letter-spacing:-0.01em}
.plan .amt small{font-size:13px;font-weight:600;color:var(--paper-dim);letter-spacing:.08em}
.plan ul{list-style:none;margin:24px 0;flex:1}
.plan li{padding:11px 0;border-bottom:1px solid var(--line);font-size:15px;font-weight:500;color:var(--paper-dim);display:flex;gap:10px}
.plan li::before{content:"→";color:var(--yellow);font-weight:700}
.plan .for{font-size:12.5px;font-weight:600;color:var(--paper-dim);letter-spacing:.04em;margin-bottom:20px}
.plan .btn{justify-content:center}
.guarantee{margin-top:36px;display:flex;align-items:center;justify-content:center;gap:12px;text-align:center;font-size:14px;font-weight:600;color:var(--paper-dim)}
.guarantee b{color:var(--yellow)}

/* testimonials */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testi{border:1px solid var(--line);border-radius:var(--radius);background:var(--ink-2);padding:32px 28px;display:flex;flex-direction:column;gap:20px;transition:border-color .3s,transform .3s}
.testi:hover{border-color:var(--line-strong);transform:translateY(-4px)}
.testi .stars{color:var(--yellow);font-size:15px;letter-spacing:3px}
.testi p{font-size:16.5px;font-weight:500;color:var(--paper);flex:1}
.testi .who{display:flex;align-items:center;gap:13px}
.testi .ava{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--yellow),#5C5300);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;color:var(--ink);flex-shrink:0;object-fit:cover}
.testi .who b{display:block;font-weight:700;font-size:15px}
.testi .who span{font-size:13px;font-weight:500;color:var(--paper-dim)}

/* compare */
.compare{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius)}
.compare table{width:100%;border-collapse:collapse;min-width:680px}
.compare th{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;text-align:left;padding:20px 24px;border-bottom:1px solid var(--line-strong);background:var(--ink-2)}
.compare th.us{color:var(--yellow)}
.compare td{padding:17px 24px;border-bottom:1px solid var(--line);font-size:15px;font-weight:500;color:var(--paper-dim)}
.compare td.us{color:var(--paper);font-weight:600;background:rgba(255,225,0,.04)}
.compare tr:last-child td{border-bottom:none}
.compare td:first-child{font-size:13px;font-weight:700;letter-spacing:.04em}

/* faq */
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:none;color:var(--paper);font-family:var(--font);font-weight:700;font-size:clamp(17px,2vw,20px);text-align:left;display:flex;justify-content:space-between;align-items:center;gap:24px;padding:26px 4px;cursor:pointer;transition:color .2s}
.faq-q:hover{color:var(--yellow)}
.faq-q .pm{font-size:24px;font-weight:400;color:var(--yellow);transition:transform .3s;flex-shrink:0;line-height:1}
.faq-item.open .pm{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.2,.8,.2,1)}
.faq-a p{padding:0 40px 28px 4px;color:var(--paper-dim);font-size:16px;font-weight:500;max-width:760px}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start}
.field{margin-bottom:18px}
.field label{display:block;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--paper-dim);margin-bottom:9px}
.field input,.field textarea{width:100%;background:var(--ink-2);border:1px solid var(--line-strong);border-radius:12px;color:var(--paper);font-family:var(--font);font-size:15.5px;font-weight:500;padding:15px 16px;transition:border-color .2s;outline:none}
.field input:focus,.field textarea:focus{border-color:var(--yellow)}
.field input::placeholder,.field textarea::placeholder{color:rgba(171,171,164,.6)}
.chip-row{display:flex;gap:8px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--line-strong);border-radius:999px;padding:11px 17px;cursor:pointer;color:var(--paper-dim);transition:all .2s}
.chip input{position:absolute;opacity:0;pointer-events:none}
.chip.active,.chip:hover{border-color:var(--yellow);color:var(--yellow);background:rgba(255,225,0,.07)}
.contact-note{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);margin-bottom:26px;display:flex;align-items:center;gap:9px}
.contact-note .live{width:8px;height:8px;border-radius:50%;background:var(--yellow);animation:pulse 1.8s infinite}
.form-ok{border:1px solid rgba(255,225,0,.5);background:rgba(255,225,0,.07);border-radius:12px;padding:18px;font-size:15.5px;font-weight:500;margin-bottom:18px}
.form-err{display:none;color:#FF8A8A;font-size:13.5px;font-weight:600;margin-top:-8px;margin-bottom:14px}

/* footer */
.site-footer{border-top:1px solid var(--line);background:var(--ink-2);padding:80px 0 0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:64px}
.foot h4{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-dim);margin-bottom:18px}
.foot a{display:block;padding:6px 0;color:var(--paper-dim);font-size:15px;font-weight:500;transition:color .2s}
.foot a:hover{color:var(--yellow)}
.office{margin-bottom:22px;font-size:14.5px;font-weight:500;color:var(--paper-dim)}
.office b{display:block;color:var(--paper);font-weight:700;margin-bottom:4px}
.foot-mail{font-weight:800;font-size:clamp(21px,2.6vw,30px);color:var(--paper)!important;letter-spacing:-0.01em}
.foot-mail:hover{color:var(--yellow)!important}
.foot-bottom{border-top:1px solid var(--line);padding:24px 0;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--paper-dim)}
.foot-marquee{overflow:hidden;border-top:1px solid var(--line);padding:18px 0;background:var(--ink)}
.foot-marquee .ticker-track{animation-duration:20s}
.foot-marquee .ticker-item{font-size:clamp(46px,7.5vw,92px);font-weight:900;color:transparent;-webkit-text-stroke:1.5px rgba(247,246,242,.22)}
.foot-marquee .ticker-item::after{color:var(--yellow);font-size:.4em;-webkit-text-stroke:0}

/* blog / inner pages */
.inner{padding:170px 0 100px}
.inner h1{font-weight:800;font-size:clamp(36px,5vw,60px);letter-spacing:-0.015em;margin-bottom:28px}
.inner .entry{color:var(--paper-dim);font-weight:500}
.inner .entry p{margin-bottom:1.2em}
.inner .entry a{color:var(--yellow)}
.post-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--ink-2);padding:30px;margin-bottom:22px;transition:border-color .3s}
.post-card:hover{border-color:var(--yellow)}
.post-card h2{font-weight:800;font-size:24px;margin-bottom:8px}
.post-card .meta{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--yellow);margin-bottom:10px}

/* reveal */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1)}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .rv{opacity:1;transform:none}
  .svc-preview{display:none}
}
:focus-visible{outline:2px solid var(--yellow);outline-offset:3px}

/* responsive */
@media(max-width:1080px){
  .svc-desc{display:none}
  .svc-row{grid-template-columns:48px 1fr auto auto auto;gap:16px}
}
@media(max-width:1000px){
  .nav-links{display:none}
  .burger{display:block}
  .hero{padding-top:110px}
  .hero-bottom{grid-template-columns:1fr;gap:32px}
  .hero-actions{align-items:flex-start}
  .hero-actions .row{justify-content:flex-start}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .work-grid,.arch-grid{grid-template-columns:1fr}
  .sprint-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .price-grid,.testi-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .svc-preview{display:none}
}
@media(max-width:640px){
  html, body{overflow-x:hidden;width:100%}
  .wrap{padding:0 16px;max-width:100%;overflow-x:hidden}
  .nav{height:72px;padding:0 16px;gap:12px;max-width:100%;overflow-x:hidden}
  .logo{font-size:18px;min-width:0;overflow:hidden;text-overflow:ellipsis}
  .nav-cta{gap:8px;min-width:0}
  .es-section{padding:72px 0;scroll-margin-top:80px;max-width:100%;overflow-x:hidden}
  .nav-cta .btn-yellow{display:none}
  .burger{padding:10px 16px;font-size:12px;white-space:nowrap}
  .mobile-menu{padding:12px 16px 24px;max-width:100%;overflow-x:hidden}
  .hero{padding-top:100px;max-width:100%;overflow-x:hidden}
  .hero-top{gap:16px;flex-wrap:wrap}
  .hero-tags{gap:6px;flex-wrap:wrap}
  .tag{font-size:11px;padding:7px 12px}
  .hero-title{margin:40px 0 0}
  .hero-bottom{gap:28px;margin:48px 0 56px}
  .hero-copy{font-size:17px}
  .btn{padding:14px 24px}
  .stat{padding:28px 16px}
  .stats .wrap{padding:0}
  .ticker-item{font-size:18px;gap:48px}
  .ticker-track{gap:48px}
  .work-info{padding:16px 18px}
  .work-name{font-size:19px;overflow:hidden;text-overflow:ellipsis}
  .svc-row{grid-template-columns:1fr auto;row-gap:10px;padding:24px 10px}
  .svc-num,.svc-go{display:none}
  .svc-price{grid-column:1}
  .svc-ship{font-size:10px;padding:6px 10px;white-space:nowrap}
  .arch-card{padding:30px 24px}
  .sprint p{font-size:16px}
  .plan{padding:30px 22px}
  .testi{padding:26px 22px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-grid .foot:first-child{grid-column:1 / -1}
  .site-footer{padding:64px 0 0;max-width:100%;overflow-x:hidden}
  .foot-bottom{padding:20px 0;flex-wrap:wrap}
  .chip-row{gap:6px;flex-wrap:wrap}
  .chip{padding:9px 14px;font-size:11px}
  .compare{overflow-x:auto}
}
@media(max-width:460px){
  .stats-grid{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid var(--line)}
  .stat:last-child{border-bottom:none}
  .hero-title{font-size:clamp(48px,12vw,60px)}
}
