
/* ===================== AA CONSULTANCY DESIGN SYSTEM (logo-driven) ===================== */
:root{
  --coral:#FB5F47;--coral-deep:#DD4830;--coral-soft:#FF8A72;
  --tint:#FFE9E3;--tint-2:#FFF4F0;
  --ink:#1B1210;--ink-2:#251915;--ink-3:#31211C;
  --cream:#FBF5F1;--white:#FFFFFF;
  --text:#241A16;--muted:#75655E;--muted-light:#B3A39B;
  --line:rgba(27,18,16,.09);--line-dark:rgba(251,245,241,.1);
  --f-h1:'Outfit',sans-serif;
  --f-h2:'SF Pro Display','SF Pro',-apple-system,BlinkMacSystemFont,'Segoe UI','Outfit',sans-serif;
  --f-h3:'Montserrat',sans-serif;
  --f-ui:'Poppins',sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);--rad:20px;
  --shadow-md:0 18px 44px -16px rgba(27,18,16,.16);
  --shadow-lg:0 34px 80px -28px rgba(27,18,16,.26);
  --shadow-coral:0 18px 44px -12px rgba(251,95,71,.45);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-ui);font-weight:400;color:var(--text);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.7;font-size:16px}
::selection{background:var(--coral);color:#fff}
img,svg{max-width:100%}
a{text-decoration:none;color:inherit}
button{font-family:var(--f-ui)}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
h1{font-family:var(--f-h1);font-weight:600;line-height:1.06;letter-spacing:-.025em}
h2{font-family:var(--f-h2);font-weight:700;line-height:1.12;letter-spacing:-.02em}
h3{font-family:var(--f-h3);font-weight:600;line-height:1.3;letter-spacing:-.005em}
.h-display{font-size:clamp(2.5rem,6.4vw,5.4rem)}
.h-sec{font-size:clamp(1.85rem,4.1vw,3.2rem);margin-top:20px}
.h-sec .mark{color:var(--coral);position:relative}
.h-sec .mark::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.32em;background:var(--tint);z-index:-1;border-radius:4px}
.on-dark .h-sec .mark::after{background:rgba(251,95,71,.18)}
.kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-h3);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--coral);font-weight:700}
.kicker::before{content:"";width:30px;height:2px;background:var(--coral);border-radius:2px;flex-shrink:0}
.sec-lead{max-width:580px;color:var(--muted);font-size:1.02rem;margin-top:18px;font-weight:300}
.on-dark .sec-lead{color:var(--muted-light)}
section{position:relative}
.ico{width:24px;height:24px;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;fill:none}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;padding:17px 32px;border-radius:100px;font-family:var(--f-ui);font-weight:500;font-size:.93rem;letter-spacing:.01em;transition:all .45s var(--ease);cursor:pointer;border:none;position:relative;overflow:hidden;isolation:isolate}
.btn::before{content:"";position:absolute;inset:0;border-radius:inherit;background:rgba(255,255,255,.18);transform:translateX(-101%) skewX(-12deg);transition:transform .6s var(--ease);z-index:-1}
.btn:hover::before{transform:translateX(0) skewX(0)}
.btn .arr{transition:transform .45s var(--ease)}
.btn:hover .arr{transform:translateX(5px)}
.btn-coral{background:var(--coral);color:#fff}
.btn-coral:hover{background:var(--coral-deep);box-shadow:var(--shadow-coral);transform:translateY(-3px)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(251,245,241,.3)}
.btn-ghost:hover{border-color:var(--coral-soft);color:var(--coral-soft);transform:translateY(-3px)}
.btn-ink{background:var(--ink);color:var(--cream)}
.btn-ink:hover{background:var(--coral);transform:translateY(-3px);box-shadow:var(--shadow-coral)}

/* Reveal */
.rv{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv-l{opacity:0;transform:translateX(-44px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.rv-l.in{opacity:1;transform:none}
.rv-s{opacity:0;transform:scale(.92);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.rv-s.in{opacity:1;transform:none}

/* ===================== LOADER ===================== */
#loader{position:fixed;inset:0;background:var(--ink);z-index:1000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:28px;transition:opacity .8s var(--ease),visibility .8s}
#loader.done{opacity:0;visibility:hidden}
#loader img{width:88px;animation:logoIn 1.2s var(--ease) both,breathe 2.4s ease-in-out 1.2s infinite}
@keyframes logoIn{from{opacity:0;transform:scale(.7) rotate(-8deg)}to{opacity:1;transform:none}}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.loader-bar{width:170px;height:2px;background:rgba(251,245,241,.12);overflow:hidden;border-radius:2px}
.loader-bar i{display:block;height:100%;width:0;background:var(--coral);animation:load 1.3s var(--ease) forwards}
@keyframes load{to{width:100%}}
.loader-tag{font-family:var(--f-h3);font-size:.64rem;letter-spacing:.34em;text-transform:uppercase;color:var(--muted-light);font-weight:600}

/* ===================== NAV ===================== */
header{position:fixed;top:0;left:0;right:0;z-index:900;transition:all .5s var(--ease);padding:18px 0;background:rgba(27,18,16,0)}
header .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px}
header.scrolled,header.solid{background:rgba(27,18,16,.88);backdrop-filter:blur(20px);padding:11px 0;border-bottom:1px solid var(--line-dark)}
.logo{display:flex;align-items:center;gap:12px;color:#fff;flex-shrink:0}
.logo img{width:44px;height:44px;transition:transform .5s var(--ease)}
.logo:hover img{transform:rotate(-10deg) scale(1.07)}
.logo-text{font-family:var(--f-h1);font-size:1.16rem;font-weight:600;letter-spacing:-.01em;line-height:1.15}
.logo-text small{display:block;font-family:var(--f-h3);font-size:.54rem;letter-spacing:.3em;text-transform:uppercase;color:var(--coral-soft);font-weight:600;margin-top:2px}
nav.menu{display:flex;gap:30px;align-items:center}
nav.menu>a,.drop>button{color:rgba(251,245,241,.82);font-size:.86rem;font-weight:400;position:relative;padding:6px 0;transition:color .3s;background:none;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-family:var(--f-ui)}
nav.menu>a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;border-radius:2px;background:var(--coral);transition:width .4s var(--ease)}
nav.menu>a:hover{color:#fff}
nav.menu>a:hover::after{width:100%}
nav.menu>a.active{color:var(--coral-soft)}
.drop{position:relative}
.drop>button .car{transition:transform .35s var(--ease);font-size:.6rem}
.drop:hover>button{color:#fff}
.drop:hover>button .car{transform:rotate(180deg)}
.drop-menu{position:absolute;top:calc(100% + 14px);left:50%;transform:translate(-50%,8px);background:var(--ink-2);border:1px solid var(--line-dark);border-radius:16px;padding:10px;min-width:250px;opacity:0;visibility:hidden;transition:all .4s var(--ease);box-shadow:0 30px 70px -20px rgba(0,0,0,.6)}
.drop:hover .drop-menu{opacity:1;visibility:visible;transform:translate(-50%,0)}
.drop-menu a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:11px;color:rgba(251,245,241,.85);font-size:.84rem;transition:all .3s}
.drop-menu a:hover{background:rgba(251,95,71,.14);color:#fff;padding-left:18px}
.drop-menu a svg{width:17px;height:17px;stroke:var(--coral-soft);flex-shrink:0}
.nav-cta{padding:12px 24px;font-size:.82rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;z-index:950;padding:6px}
.burger span{width:26px;height:2px;background:#fff;border-radius:2px;transition:all .4s var(--ease)}
@media(max-width:1080px){
  nav.menu{position:fixed;inset:0;background:var(--ink);flex-direction:column;align-items:center;justify-content:center;gap:6px;transform:translateY(-100%);transition:transform .6s var(--ease);overflow-y:auto;padding:90px 24px 50px}
  nav.menu.open{transform:none}
  nav.menu>a{font-size:1.3rem;font-family:var(--f-h1);font-weight:500;padding:10px 0}
  .drop{width:100%;max-width:340px;text-align:center}
  .drop>button{font-size:1.3rem;font-family:var(--f-h1);font-weight:500;width:100%;justify-content:center;padding:10px 0}
  .drop-menu{position:static;transform:none;opacity:1;visibility:visible;background:rgba(251,245,241,.04);box-shadow:none;display:none;margin-top:6px}
  .drop.open .drop-menu{display:block}
  .drop.open>button .car{transform:rotate(180deg)}
  .burger{display:flex}
  .burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav-cta{display:none}
}

/* ===================== HOME HERO ===================== */
.hero{min-height:100svh;background:var(--ink);color:var(--cream);display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;padding:150px 0 70px}
.hero-glow{position:absolute;inset:0;pointer-events:none}
.hero-glow::before{content:"";position:absolute;width:820px;height:820px;border-radius:50%;background:radial-gradient(circle,rgba(251,95,71,.22),transparent 62%);top:-300px;right:-220px;animation:drift 16s ease-in-out infinite alternate}
.hero-glow::after{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(251,95,71,.1),transparent 62%);bottom:-200px;left:-160px;animation:drift 20s ease-in-out infinite alternate-reverse}
@keyframes drift{to{transform:translate(70px,46px) scale(1.1)}}
.hero-leaf{position:absolute;right:-14vw;top:50%;transform:translateY(-50%);width:58vw;max-width:880px;opacity:.045;pointer-events:none;animation:leafFloat 12s ease-in-out infinite}
@keyframes leafFloat{0%,100%{transform:translateY(-50%) rotate(0)}50%{transform:translateY(-53%) rotate(2deg)}}
.hero-dots{position:absolute;inset:0;background-image:radial-gradient(rgba(251,245,241,.05) 1px,transparent 1px);background-size:34px 34px;mask-image:radial-gradient(ellipse 80% 65% at 42% 42%,black,transparent)}
.hero .wrap{display:grid;grid-template-columns:1.12fr .88fr;gap:60px;align-items:center;position:relative;z-index:2}
.hero-eyebrow{display:inline-flex;align-items:center;gap:12px;border:1px solid rgba(251,245,241,.16);border-radius:100px;padding:9px 18px;font-family:var(--f-h3);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--coral-soft);margin-bottom:32px;background:rgba(251,245,241,.04);font-weight:600}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--coral);animation:pulse 2s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(251,95,71,.55)}55%{box-shadow:0 0 0 9px rgba(251,95,71,0)}}
.hero h1 .accent{color:var(--coral)}
.hero h1 .outline{color:transparent;-webkit-text-stroke:1.5px rgba(251,245,241,.6)}
.hero-sub{max-width:520px;color:var(--muted-light);font-size:1.04rem;margin:26px 0 40px;font-weight:300}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{display:flex;gap:14px 32px;margin-top:56px;flex-wrap:wrap}
.hero-meta div{font-family:var(--f-h3);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(251,245,241,.45);display:flex;align-items:center;gap:9px;font-weight:600}
.hero-meta div::before{content:"";width:8px;height:8px;background:var(--coral);border-radius:50% 50% 50% 0;transform:rotate(-45deg);flex-shrink:0}
.hero-visual{position:relative;height:560px}
.hv-leafcard{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:350px;aspect-ratio:1;border-radius:50% 16% 50% 50%;background:linear-gradient(150deg,var(--coral) 0%,var(--coral-deep) 110%);box-shadow:0 50px 110px -30px rgba(251,95,71,.5);display:grid;place-items:center;animation:floaty 8s ease-in-out infinite;overflow:hidden}
.hv-leafcard::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.14) 1px,transparent 1px);background-size:20px 20px;opacity:.5}
.hv-leafcard img{width:62%;filter:drop-shadow(0 12px 30px rgba(0,0,0,.22))}
.hv-card{position:absolute;background:rgba(37,25,21,.78);border:1px solid rgba(251,245,241,.12);backdrop-filter:blur(16px);border-radius:18px;padding:16px 19px;box-shadow:0 28px 60px -18px rgba(0,0,0,.55);animation:floaty 7s ease-in-out infinite}
.hv-card .t1{font-family:var(--f-h3);font-size:.76rem;font-weight:600;color:#fff}
.hv-card .t2{font-size:.66rem;color:var(--muted-light);margin-top:2px;font-weight:300}
.hv-card .ic{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}
.hv-card .ic svg{width:17px;height:17px}
.hv-row{display:flex;align-items:center;gap:13px}
.hv-1{top:36px;left:-6px;animation-delay:-2s}.hv-1 .ic{background:rgba(251,95,71,.18)}.hv-1 svg{stroke:var(--coral-soft)}
.hv-2{top:120px;right:-16px;animation-delay:-4.5s}.hv-2 .ic{background:rgba(255,196,80,.14)}.hv-2 svg{stroke:#FFC450}
.hv-3{bottom:96px;left:-22px;animation-delay:-1.2s}.hv-3 .ic{background:rgba(110,231,183,.12)}.hv-3 svg{stroke:#6EE7B7}
.hv-4{bottom:8px;right:28px;animation-delay:-5.6s}.hv-4 .ic{background:rgba(251,95,71,.18)}.hv-4 svg{stroke:var(--coral-soft)}
.hv-spark{position:absolute;border-radius:50%;background:var(--coral);opacity:.5}
.hv-s1{width:10px;height:10px;top:80px;right:96px;animation:floaty 5s ease-in-out -1s infinite}
.hv-s2{width:6px;height:6px;bottom:130px;right:60px;animation:floaty 6s ease-in-out -3s infinite}
.hv-s3{width:8px;height:8px;top:200px;left:30px;animation:floaty 7s ease-in-out -2s infinite}
@keyframes floaty{0%,100%{margin-top:0}50%{margin-top:-18px}}
@media(max-width:1080px){.hero .wrap{grid-template-columns:1fr}.hero-visual{display:none}}

/* marquee */
.marquee{background:var(--coral);padding:16px 0;overflow:hidden;position:relative;transform:rotate(-1deg) scale(1.02);margin-top:-24px;z-index:5;box-shadow:0 18px 50px -16px rgba(251,95,71,.5)}
.marquee-track{display:flex;width:max-content;animation:mq 26s linear infinite}
.marquee span{font-family:var(--f-h3);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;white-space:nowrap;padding:0 24px;display:flex;align-items:center;gap:48px}
.marquee span::after{content:"\2042";font-size:.8rem;opacity:.7}
@keyframes mq{to{transform:translateX(-50%)}}

/* ===================== STATS ===================== */
.stats{background:var(--ink);color:var(--cream);padding:110px 0 100px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-dark);border:1px solid var(--line-dark);border-radius:var(--rad);overflow:hidden}
.stat{background:var(--ink-2);padding:46px 36px;position:relative;transition:background .5s var(--ease);overflow:hidden}
.stat:hover{background:var(--ink-3)}
.stat::before{content:"";position:absolute;top:0;left:0;width:0;height:3px;background:var(--coral);transition:width .6s var(--ease)}
.stat:hover::before{width:100%}
.stat::after{content:"";position:absolute;bottom:-46px;right:-26px;width:120px;height:120px;border-radius:50% 50% 50% 0;background:rgba(251,95,71,.06);transform:rotate(-45deg);transition:transform .6s var(--ease)}
.stat:hover::after{transform:rotate(-45deg) scale(1.4)}
.stat-num{font-family:var(--f-h1);font-weight:600;font-size:clamp(2.4rem,4vw,3.7rem);color:#fff;line-height:1;position:relative}
.stat-num sup{font-size:.42em;color:var(--coral);margin-left:3px}
.stat-label{font-family:var(--f-h3);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-light);margin-top:14px;font-weight:600;position:relative}
@media(max-width:900px){.stats-grid{grid-template-columns:1fr 1fr}}

/* ===================== ABOUT ===================== */
.about{padding:140px 0;background:var(--white);overflow:hidden}
.about .wrap{display:grid;grid-template-columns:1fr 1fr;gap:90px;align-items:center}
.about-visual{position:relative}
.about-frame{aspect-ratio:4/4.5;border-radius:46% 14% 30% 30% / 38% 14% 26% 26%;background:linear-gradient(155deg,var(--ink) 10%,var(--ink-3) 120%);position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.about-frame .dots{position:absolute;inset:0;background-image:radial-gradient(rgba(251,245,241,.07) 1px,transparent 1px);background-size:22px 22px}
.about-frame .leaf{position:absolute;bottom:-70px;right:-60px;width:330px;opacity:.1;transform:rotate(-14deg)}
.about-frame .quote{position:absolute;top:46px;left:40px;right:50px;font-family:var(--f-h2);font-weight:700;font-size:clamp(1.15rem,1.7vw,1.55rem);color:var(--cream);line-height:1.4;letter-spacing:-.01em}
.about-frame .quote::before{content:"\201C";display:block;font-family:var(--f-h1);font-size:3.6rem;color:var(--coral);line-height:.55;margin-bottom:16px}
.about-card{position:absolute;bottom:34px;left:-46px;background:var(--white);border-radius:18px;padding:18px 24px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:15px;border:1px solid var(--line);max-width:88%}
.about-card img{width:44px;height:44px;flex-shrink:0}
.about-card b{display:block;font-family:var(--f-h3);font-size:.86rem;font-weight:700}
.about-card small{color:var(--muted);font-size:.72rem;font-weight:300}
.about-badge{position:absolute;top:28px;right:-18px;background:var(--coral);color:#fff;border-radius:100px;padding:12px 22px;font-family:var(--f-h3);font-weight:700;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;box-shadow:var(--shadow-coral);animation:floaty 6s ease-in-out infinite}
.about-body>p{color:var(--muted);margin-top:24px;font-size:.98rem;font-weight:300}
.about-points{margin-top:36px;display:grid}
.about-point{display:flex;gap:20px;padding:22px 0;border-top:1px solid var(--line);transition:padding-left .4s var(--ease)}
.about-point:hover{padding-left:10px}
.about-point:last-child{border-bottom:1px solid var(--line)}
.about-point .n{font-family:var(--f-h1);font-weight:600;font-size:.95rem;color:var(--coral);padding-top:2px}
.about-point h3{font-size:1.05rem;margin-bottom:5px}
.about-point p{margin:0;font-size:.88rem;color:var(--muted);font-weight:300}
@media(max-width:1080px){.about .wrap{grid-template-columns:1fr;gap:74px}.about-card{left:10px}.about-badge{right:6px}}

/* ===================== SERVICES GRID (home) ===================== */
.services{background:var(--cream);padding:140px 0;position:relative;overflow:hidden}
.services::before{content:"";position:absolute;top:-180px;left:-180px;width:480px;height:480px;border-radius:50% 50% 50% 0;background:var(--tint);transform:rotate(-45deg);opacity:.7}
.svc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:34px;flex-wrap:wrap;margin-bottom:66px;position:relative}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
.svc{background:var(--white);border:1px solid var(--line);border-radius:var(--rad);padding:40px 32px;position:relative;overflow:hidden;transition:transform .55s var(--ease),box-shadow .55s var(--ease);display:flex;flex-direction:column;min-height:380px}
.svc:hover{transform:translateY(-12px);box-shadow:var(--shadow-lg)}
.svc::after{content:"";position:absolute;top:-110px;right:-110px;width:220px;height:220px;border-radius:50% 50% 50% 0;background:linear-gradient(150deg,var(--coral),var(--coral-deep));transform:rotate(-45deg) scale(0);transition:transform .65s var(--ease);z-index:0}
.svc:hover::after{transform:rotate(-45deg) scale(1)}
.svc>*{position:relative;z-index:1}
.svc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:auto}
.svc-num{font-family:var(--f-h1);font-weight:600;font-size:.8rem;color:var(--muted-light);letter-spacing:.1em;transition:color .5s}
.svc:hover .svc-num{color:#fff}
.svc-icon{width:58px;height:58px;border-radius:50% 50% 50% 0;background:var(--tint);display:grid;place-items:center;transition:all .55s var(--ease);transform:rotate(-45deg)}
.svc-icon svg{width:24px;height:24px;stroke:var(--coral);transform:rotate(45deg);transition:stroke .5s}
.svc:hover .svc-icon{background:rgba(255,255,255,.18);transform:rotate(-45deg) scale(1.08)}
.svc:hover .svc-icon svg{stroke:#fff}
.svc h3{font-size:1.2rem;margin:28px 0 12px}
.svc p{color:var(--muted);font-size:.88rem;font-weight:300}
.svc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.svc-tags span{font-family:var(--f-h3);font-weight:600;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:100px;background:var(--cream);color:var(--muted)}
.svc-link{margin-top:24px;font-size:.85rem;font-weight:500;color:var(--coral);display:inline-flex;align-items:center;gap:9px}
.svc-link .arr{transition:transform .4s var(--ease)}
.svc:hover .svc-link .arr{transform:translateX(6px)}
@media(max-width:1080px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.svc-grid{grid-template-columns:1fr}.svc{min-height:0}}

/* ===================== INDUSTRIES ===================== */
.industries{background:var(--white);padding:140px 0}
.ind-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:60px}
.ind{border:1px solid var(--line);border-radius:18px;padding:30px 20px;text-align:center;transition:all .5s var(--ease);cursor:default;background:var(--white);position:relative;overflow:hidden}
.ind::before{content:"";position:absolute;inset:0;background:linear-gradient(155deg,var(--coral),var(--coral-deep));opacity:0;transition:opacity .5s var(--ease)}
.ind-icon{width:52px;height:52px;margin:0 auto 16px;border-radius:50% 50% 50% 0;background:var(--tint);display:grid;place-items:center;transform:rotate(-45deg);transition:all .5s var(--ease);position:relative}
.ind-icon svg{width:22px;height:22px;stroke:var(--coral);transform:rotate(45deg);transition:stroke .4s}
.ind b{font-family:var(--f-h3);font-size:.8rem;font-weight:600;color:var(--text);transition:color .4s;position:relative}
.ind:hover{transform:translateY(-7px);box-shadow:var(--shadow-coral);border-color:transparent}
.ind:hover::before{opacity:1}
.ind:hover .ind-icon{background:rgba(255,255,255,.16);transform:rotate(-45deg) scale(1.1)}
.ind:hover .ind-icon svg{stroke:#fff}
.ind:hover b{color:#fff}
@media(max-width:1080px){.ind-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.ind-grid{grid-template-columns:repeat(2,1fr);gap:12px}.ind{padding:24px 14px}}

/* ===================== WHY ===================== */
.why{background:var(--ink);color:var(--cream);padding:150px 0;position:relative;overflow:hidden}
.why::before{content:"";position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(251,95,71,.14),transparent 62%);top:-240px;left:-240px}
.why .leaf-bg{position:absolute;bottom:-120px;right:-100px;width:480px;opacity:.04;transform:rotate(160deg)}
.why .wrap{position:relative;z-index:1}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:66px}
.why-card{background:rgba(251,245,241,.04);border:1px solid var(--line-dark);border-radius:var(--rad);padding:36px 30px;transition:all .5s var(--ease);position:relative;overflow:hidden}
.why-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--coral),transparent);opacity:0;transition:opacity .5s}
.why-card:hover{background:rgba(251,245,241,.07);transform:translateY(-8px);border-color:rgba(251,95,71,.35)}
.why-card:hover::before{opacity:1}
.why-icon{width:52px;height:52px;border-radius:50% 50% 50% 0;background:rgba(251,95,71,.15);display:grid;place-items:center;margin-bottom:24px;transform:rotate(-45deg);transition:transform .5s var(--ease)}
.why-card:hover .why-icon{transform:rotate(-45deg) scale(1.1)}
.why-icon svg{width:22px;height:22px;stroke:var(--coral-soft);transform:rotate(45deg)}
.why-card h3{font-size:1.08rem;margin-bottom:10px;color:#fff}
.why-card p{color:var(--muted-light);font-size:.87rem;font-weight:300}
.vs{margin-top:84px;display:grid;grid-template-columns:1fr 1fr;gap:24px}
.vs-col{border-radius:var(--rad);padding:44px 40px;border:1px solid var(--line-dark)}
.vs-col.them{background:rgba(251,245,241,.025)}
.vs-col.us{background:linear-gradient(160deg,rgba(251,95,71,.16),rgba(251,95,71,.04));border-color:rgba(251,95,71,.4);position:relative}
.vs-col.us::before{content:"THE AA STANDARD";position:absolute;top:-12px;left:40px;background:var(--coral);color:#fff;font-family:var(--f-h3);font-size:.58rem;letter-spacing:.2em;padding:6px 15px;border-radius:100px;font-weight:700}
.vs-col h3{font-size:1.25rem;margin-bottom:26px;color:#fff}
.vs-col.them h3{color:var(--muted-light)}
.vs-col ul{list-style:none;display:grid;gap:16px}
.vs-col li{display:flex;gap:14px;font-size:.9rem;align-items:flex-start;font-weight:300}
.vs-col.them li{color:var(--muted-light)}
.vs-col li .m{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:.6rem;margin-top:2px}
.vs-col.us li .m{background:rgba(251,95,71,.25);color:var(--coral-soft)}
.vs-col.them li .m{background:rgba(251,245,241,.07);color:var(--muted-light)}
@media(max-width:1080px){.why-grid{grid-template-columns:1fr 1fr}.vs{grid-template-columns:1fr}}
@media(max-width:680px){.why-grid{grid-template-columns:1fr}.vs-col{padding:36px 26px}}

/* ===================== PROCESS ===================== */
.process{background:var(--cream);padding:150px 0;overflow:hidden;position:relative}
.process::after{content:"";position:absolute;bottom:-160px;right:-160px;width:440px;height:440px;border-radius:50% 50% 50% 0;background:var(--tint);transform:rotate(135deg);opacity:.6}
.proc-track{margin-top:80px;position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;z-index:1}
.proc-track::before{content:"";position:absolute;top:31px;left:7%;right:7%;height:2px;background:repeating-linear-gradient(90deg,var(--coral) 0 9px,transparent 9px 19px);opacity:.3}
.step{position:relative}
.step-dot{width:62px;height:62px;border-radius:50% 50% 50% 0;background:var(--white);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--f-h1);font-weight:600;color:var(--coral);font-size:1rem;position:relative;z-index:1;transition:all .5s var(--ease);box-shadow:var(--shadow-md);transform:rotate(-45deg)}
.step-dot i{font-style:normal;transform:rotate(45deg)}
.step:hover .step-dot{background:var(--coral);color:#fff;border-color:var(--coral);transform:rotate(-45deg) scale(1.14);box-shadow:var(--shadow-coral)}
.step h3{font-size:1.12rem;margin:26px 0 9px}
.step p{color:var(--muted);font-size:.87rem;font-weight:300}
.step .ph{font-family:var(--f-h3);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--coral);display:block;margin-top:18px;font-weight:700}
@media(max-width:1080px){.proc-track{grid-template-columns:1fr 1fr;gap:50px 28px}.proc-track::before{display:none}}
@media(max-width:560px){.proc-track{grid-template-columns:1fr;gap:44px}}

/* ===================== TESTIMONIALS ===================== */
.testi{background:var(--white);padding:150px 0;position:relative;overflow:hidden}
.testi::before{content:"\201D";position:absolute;top:-70px;left:3%;font-family:var(--f-h1);font-weight:700;font-size:22rem;color:var(--tint);line-height:1;pointer-events:none}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:66px;position:relative}
.tcard{border:1px solid var(--line);border-radius:var(--rad);padding:40px 32px;background:linear-gradient(170deg,var(--white),var(--tint-2));transition:all .55s var(--ease);display:flex;flex-direction:column}
.tcard:hover{transform:translateY(-10px) rotate(-.5deg);box-shadow:var(--shadow-lg);border-color:rgba(251,95,71,.4)}
.stars{color:var(--coral);letter-spacing:4px;font-size:.86rem;margin-bottom:22px}
.tcard blockquote{font-size:.96rem;line-height:1.75;color:var(--text);flex:1;font-weight:300}
.t-person{display:flex;align-items:center;gap:14px;margin-top:28px;padding-top:24px;border-top:1px solid var(--line)}
.t-avatar{width:48px;height:48px;border-radius:50% 50% 50% 0;background:linear-gradient(145deg,var(--coral),var(--coral-deep));color:#fff;display:grid;place-items:center;font-family:var(--f-h3);font-size:.76rem;font-weight:700;flex-shrink:0}
.t-person b{display:block;font-family:var(--f-h3);font-size:.88rem;font-weight:700}
.t-person small{color:var(--muted);font-size:.74rem;font-weight:300}
.t-metric{margin-top:16px;display:inline-flex;align-self:flex-start;gap:8px;align-items:center;font-family:var(--f-h3);font-weight:700;font-size:.6rem;letter-spacing:.12em;color:var(--coral-deep);background:var(--tint);padding:8px 14px;border-radius:100px}
@media(max-width:1080px){.testi-grid{grid-template-columns:1fr}}

/* ===================== FAQ ===================== */
.faq{background:var(--cream);padding:150px 0}
.faq .wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:76px;align-items:start}
.faq-list{display:grid;gap:13px}
.faq-item{background:var(--white);border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:all .4s}
.faq-item.open{border-color:rgba(251,95,71,.45);box-shadow:var(--shadow-md)}
.faq-q{width:100%;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:22px 26px;font-size:.95rem;font-weight:500;color:var(--text);text-align:left}
.faq-q .pm{width:32px;height:32px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;flex-shrink:0;transition:all .45s var(--ease);font-weight:400;color:var(--coral);font-size:1.05rem}
.faq-item.open .pm{background:var(--coral);color:#fff;border-color:var(--coral);transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .55s var(--ease)}
.faq-a p{padding:0 26px 24px;color:var(--muted);font-size:.9rem;font-weight:300}
.faq-side{position:sticky;top:110px}
@media(max-width:1080px){.faq .wrap{grid-template-columns:1fr;gap:48px}.faq-side{position:static}}

/* ===================== CTA ===================== */
.cta{background:var(--ink);padding:150px 0;position:relative;overflow:hidden;color:var(--cream);text-align:center}
.cta::before{content:"";position:absolute;width:920px;height:920px;left:50%;top:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(251,95,71,.2),transparent 58%);pointer-events:none}
.cta .leaf-bg{position:absolute;top:-150px;left:-130px;width:460px;opacity:.045;transform:rotate(40deg)}
.cta .wrap{position:relative;z-index:1;max-width:860px}
.cta h2{font-size:clamp(2.2rem,5.4vw,4.3rem);color:#fff}
.cta h2 .accent{color:var(--coral)}
.cta p{color:var(--muted-light);max-width:520px;margin:24px auto 44px;font-size:1.02rem;font-weight:300}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-contact{margin-top:52px;display:flex;gap:16px 36px;justify-content:center;flex-wrap:wrap;font-size:.88rem;color:var(--muted-light);font-weight:300}
.cta-contact a{display:flex;align-items:center;gap:9px;transition:color .3s}
.cta-contact a:hover{color:var(--coral-soft)}
.cta-contact svg{width:16px;height:16px;stroke:var(--coral)}

/* ===================== FOOTER ===================== */
footer{background:#140D0B;color:var(--muted-light);padding:84px 0 0;border-top:1px solid var(--line-dark)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:54px;padding-bottom:64px}
.foot-brand p{font-size:.86rem;margin:22px 0 26px;max-width:300px;font-weight:300}
.foot-social{display:flex;gap:12px}
.foot-social a{width:42px;height:42px;border-radius:50% 50% 50% 0;border:1px solid var(--line-dark);display:grid;place-items:center;transition:all .4s var(--ease)}
.foot-social a:hover{background:var(--coral);border-color:var(--coral);transform:translateY(-4px) rotate(-8deg)}
.foot-social svg{width:16px;height:16px;fill:var(--muted-light);transition:fill .4s}
.foot-social a:hover svg{fill:#fff}
.foot-col h3{font-family:var(--f-h3);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:#fff;margin-bottom:22px;font-weight:700}
.foot-col ul{list-style:none;display:grid;gap:12px}
.foot-col a{font-size:.86rem;transition:all .3s;display:inline-flex;gap:9px;align-items:center;font-weight:300}
.foot-col a:hover{color:var(--coral-soft);padding-left:5px}
.foot-col a svg{width:15px;height:15px;stroke:var(--coral);flex-shrink:0}
.news-in{display:flex;margin-top:16px;border:1px solid var(--line-dark);border-radius:100px;overflow:hidden;background:rgba(251,245,241,.03);transition:border-color .3s}
.news-in:focus-within{border-color:var(--coral)}
.news-in input{flex:1;background:none;border:none;padding:14px 18px;color:#fff;font-family:var(--f-ui);font-size:.84rem;outline:none;min-width:0;font-weight:300}
.news-in input::placeholder{color:rgba(251,245,241,.35)}
.news-in button{background:var(--coral);border:none;color:#fff;font-weight:500;padding:0 22px;cursor:pointer;font-size:.82rem;transition:background .3s}
.news-in button:hover{background:var(--coral-deep)}
.foot-bottom{border-top:1px solid var(--line-dark);padding:26px 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.76rem;font-weight:300}
.foot-bottom em{color:var(--coral-soft);font-style:normal;font-weight:400}
@media(max-width:1080px){.foot-grid{grid-template-columns:1fr 1fr;gap:44px}}
@media(max-width:600px){.foot-grid{grid-template-columns:1fr;gap:40px}}

/* floating */
.float-wa{position:fixed;bottom:24px;right:24px;z-index:800;width:56px;height:56px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 14px 36px -8px rgba(37,211,102,.55);transition:transform .4s var(--ease)}
.float-wa::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #25D366;animation:ring 2.2s var(--ease) infinite}
@keyframes ring{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.55);opacity:0}}
.float-wa:hover{transform:scale(1.12) rotate(8deg)}
.float-wa svg{width:27px;height:27px;fill:#fff}
.to-top{position:fixed;bottom:24px;left:24px;z-index:800;width:46px;height:46px;border-radius:50% 50% 50% 0;background:var(--ink);color:var(--coral-soft);border:1px solid var(--line-dark);display:grid;place-items:center;cursor:pointer;opacity:0;visibility:hidden;transition:all .45s var(--ease);font-size:1rem}
.to-top.show{opacity:1;visibility:visible}
.to-top:hover{background:var(--coral);color:#fff;transform:translateY(-4px)}

/* ===================== SERVICE PAGES ===================== */
.page-hero{background:var(--ink);color:var(--cream);padding:190px 0 120px;position:relative;overflow:hidden}
.page-hero .hero-glow::before{width:640px;height:640px;top:-260px;right:-180px}
.page-hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr .8fr;gap:60px;align-items:center}
.crumb{display:flex;align-items:center;gap:10px;font-family:var(--f-h3);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-light);font-weight:600;margin-bottom:28px;flex-wrap:wrap}
.crumb a{color:var(--coral-soft);transition:color .3s}
.crumb a:hover{color:#fff}
.crumb .sep{opacity:.4}
.page-hero h1{font-size:clamp(2.3rem,5.2vw,4.2rem);color:#fff}
.page-hero h1 .accent{color:var(--coral)}
.page-hero .lead{color:var(--muted-light);font-size:1.04rem;margin:24px 0 38px;font-weight:300;max-width:560px}
.page-hero-visual{position:relative;display:grid;place-items:center}
.ph-leaf{width:min(300px,70vw);aspect-ratio:1;border-radius:50% 16% 50% 50%;background:linear-gradient(150deg,var(--coral),var(--coral-deep));box-shadow:0 50px 110px -30px rgba(251,95,71,.5);display:grid;place-items:center;animation:floaty 8s ease-in-out infinite;position:relative;overflow:hidden}
.ph-leaf::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.14) 1px,transparent 1px);background-size:20px 20px;opacity:.5}
.ph-leaf svg{width:34%;height:34%;stroke:#fff;position:relative}
.ph-tag{position:absolute;bottom:14px;right:0;background:rgba(37,25,21,.82);backdrop-filter:blur(14px);border:1px solid rgba(251,245,241,.12);border-radius:14px;padding:13px 18px;font-family:var(--f-h3);font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--coral-soft);animation:floaty 6s ease-in-out -2s infinite}
@media(max-width:1080px){.page-hero .wrap{grid-template-columns:1fr}.page-hero-visual{display:none}.page-hero{padding:160px 0 90px}}

.svc-intro{padding:130px 0;background:var(--white)}
.svc-intro .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:start}
.svc-intro .body p{color:var(--muted);font-weight:300;font-size:.98rem;margin-top:20px}
.intro-panel{background:var(--cream);border:1px solid var(--line);border-radius:var(--rad);padding:38px 34px;position:sticky;top:110px}
.intro-panel h3{font-size:1rem;margin-bottom:22px}
.intro-panel ul{list-style:none;display:grid;gap:14px}
.intro-panel li{display:flex;gap:12px;font-size:.88rem;font-weight:300;color:var(--text);align-items:flex-start}
.intro-panel li svg{width:18px;height:18px;stroke:var(--coral);flex-shrink:0;margin-top:3px}
.intro-panel .btn{width:100%;margin-top:28px}
@media(max-width:1080px){.svc-intro .wrap{grid-template-columns:1fr;gap:48px}.intro-panel{position:static}}

.feat{background:var(--cream);padding:130px 0;position:relative;overflow:hidden}
.feat::before{content:"";position:absolute;top:-160px;right:-160px;width:430px;height:430px;border-radius:50% 50% 50% 0;background:var(--tint);transform:rotate(45deg);opacity:.6}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:64px;position:relative}
.fcard{background:var(--white);border:1px solid var(--line);border-radius:var(--rad);padding:36px 30px;transition:all .5s var(--ease)}
.fcard:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:rgba(251,95,71,.35)}
.fcard .f-icon{width:54px;height:54px;border-radius:50% 50% 50% 0;background:var(--tint);display:grid;place-items:center;transform:rotate(-45deg);margin-bottom:24px;transition:all .5s var(--ease)}
.fcard:hover .f-icon{background:var(--coral);transform:rotate(-45deg) scale(1.08)}
.fcard .f-icon svg{width:22px;height:22px;stroke:var(--coral);transform:rotate(45deg);transition:stroke .4s}
.fcard:hover .f-icon svg{stroke:#fff}
.fcard h3{font-size:1.05rem;margin-bottom:10px}
.fcard p{color:var(--muted);font-size:.87rem;font-weight:300}
@media(max-width:1080px){.feat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.feat-grid{grid-template-columns:1fr}}

.band{background:var(--ink);color:#fff;padding:90px 0}
.band-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;text-align:center}
.band-item{padding:30px 20px;border:1px solid var(--line-dark);border-radius:var(--rad);background:rgba(251,245,241,.03);transition:all .5s var(--ease)}
.band-item:hover{border-color:rgba(251,95,71,.4);background:rgba(251,95,71,.07);transform:translateY(-5px)}
.band-item .bn{font-family:var(--f-h1);font-weight:600;font-size:2.4rem;color:var(--coral-soft)}
.band-item .bl{font-family:var(--f-h3);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-light);margin-top:8px;font-weight:600}
@media(max-width:680px){.band-grid{grid-template-columns:1fr}}

.other-svcs{padding:130px 0;background:var(--white)}
.os-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:56px}
.os{border:1px solid var(--line);border-radius:18px;padding:28px 18px;text-align:center;transition:all .5s var(--ease);position:relative;overflow:hidden;display:block}
.os::before{content:"";position:absolute;inset:0;background:linear-gradient(155deg,var(--coral),var(--coral-deep));opacity:0;transition:opacity .5s var(--ease)}
.os .ind-icon{width:48px;height:48px;margin-bottom:14px}
.os b{font-family:var(--f-h3);font-size:.76rem;font-weight:600;color:var(--text);transition:color .4s;position:relative;display:block;line-height:1.4}
.os:hover{transform:translateY(-6px);box-shadow:var(--shadow-coral);border-color:transparent}
.os:hover::before{opacity:1}
.os:hover .ind-icon{background:rgba(255,255,255,.16)}
.os:hover .ind-icon svg{stroke:#fff}
.os:hover b{color:#fff}
@media(max-width:1080px){.os-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.os-grid{grid-template-columns:repeat(2,1fr);gap:12px}}

/* ===================== MOBILE POLISH ===================== */
@media(max-width:680px){
  .wrap{padding:0 20px}
  body{font-size:15px}
  section,.about,.services,.industries,.why,.process,.testi,.faq,.cta,.svc-intro,.feat,.other-svcs{padding-top:88px;padding-bottom:88px}
  .stats{padding:70px 0}
  .band{padding:60px 0}
  .hero{padding:120px 0 56px;min-height:auto}
  .hero-sub{font-size:.96rem;margin:22px 0 32px}
  .hero-ctas .btn{width:100%}
  .cta-btns .btn{width:100%;max-width:340px}
  .hero-meta{margin-top:42px;gap:12px 24px}
  .marquee{margin-top:-16px;padding:13px 0}
  .stat{padding:28px 22px}
  .about-frame .quote{top:32px;left:26px;right:30px}
  .about-card{padding:14px 18px;bottom:22px}
  .about-badge{padding:10px 18px;font-size:.62rem;top:18px}
  .svc{padding:34px 26px}
  .svc-head .btn{width:100%}
  .vs-col.us::before{left:26px}
  .faq-q{padding:19px 20px;font-size:.9rem;gap:14px}
  .faq-a p{padding:0 20px 22px}
  .page-hero{padding:140px 0 76px}
  .page-hero .lead{font-size:.96rem}
  .page-hero .btn{width:100%;max-width:340px}
  .intro-panel{padding:30px 24px}
  .float-wa{width:52px;height:52px;bottom:18px;right:18px}
  .to-top{width:42px;height:42px;bottom:18px;left:18px}
  .foot-bottom{justify-content:center;text-align:center}
}
@media(max-width:380px){
  .h-display{font-size:2.2rem}
  .hero-eyebrow{font-size:.56rem;padding:8px 14px}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important;scroll-behavior:auto!important}}

/* ===================== PORTFOLIO ===================== */
.pf-filters{display:flex;gap:10px;flex-wrap:wrap;margin-top:50px}
.pf-pill{font-family:var(--f-h3);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:11px 22px;border-radius:100px;border:1px solid var(--line);background:var(--white);color:var(--muted);cursor:pointer;transition:all .4s var(--ease)}
.pf-pill:hover{border-color:var(--coral);color:var(--coral)}
.pf-pill.on{background:var(--coral);border-color:var(--coral);color:#fff;box-shadow:var(--shadow-coral)}
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:54px}
.pf-card{border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;background:var(--white);transition:all .55s var(--ease);display:flex;flex-direction:column;position:relative}
.pf-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg);border-color:rgba(251,95,71,.4)}
.pf-card.hide{display:none}
.pf-cover{aspect-ratio:16/10;position:relative;overflow:hidden;display:grid;place-items:center}
.pf-cover::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.14) 1px,transparent 1px);background-size:20px 20px;opacity:.45}
.pf-cover::after{content:"";position:absolute;top:-60px;right:-60px;width:170px;height:170px;border-radius:50% 50% 50% 0;background:rgba(255,255,255,.1);transform:rotate(-45deg);transition:transform .6s var(--ease)}
.pf-card:hover .pf-cover::after{transform:rotate(-45deg) scale(1.5)}
.pf-mono{font-family:var(--f-h1);font-weight:700;font-size:3.2rem;color:#fff;letter-spacing:-.02em;position:relative;text-shadow:0 10px 30px rgba(0,0,0,.25);transition:transform .55s var(--ease)}
.pf-card:hover .pf-mono{transform:scale(1.08)}
.pf-cat{position:absolute;top:16px;left:16px;background:rgba(20,13,11,.55);backdrop-filter:blur(10px);color:#fff;font-family:var(--f-h3);font-size:.56rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:7px 14px;border-radius:100px;border:1px solid rgba(255,255,255,.2)}
.pf-visit{position:absolute;bottom:16px;right:16px;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;opacity:0;transform:translateY(8px);transition:all .45s var(--ease)}
.pf-visit svg{width:17px;height:17px;stroke:var(--coral-deep)}
.pf-card:hover .pf-visit{opacity:1;transform:none}
.pf-body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.pf-body h3{font-size:1.08rem;margin-bottom:9px}
.pf-body p{color:var(--muted);font-size:.86rem;font-weight:300;flex:1}
.pf-link{margin-top:18px;font-size:.84rem;font-weight:500;color:var(--coral);display:inline-flex;align-items:center;gap:8px}
.pf-link .arr{transition:transform .4s var(--ease)}
.pf-card:hover .pf-link .arr{transform:translateX(5px)}
.pf-count{font-family:var(--f-h3);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:28px}
.pf-count b{color:var(--coral)}
@media(max-width:1080px){.pf-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.pf-grid{grid-template-columns:1fr;gap:20px}.pf-pill{padding:10px 18px;font-size:.62rem}}

.pf-shot{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .65s var(--ease);background:transparent}
.pf-card:hover .pf-shot{transform:scale(1.05)}
.pf-cover{isolation:isolate}
.pf-cover .pf-cat,.pf-cover .pf-visit{z-index:2}

/* contact form fields */
.cf{width:100%;padding:16px 20px;border:1px solid var(--line);border-radius:14px;font-family:var(--f-ui);font-size:.92rem;font-weight:300;color:var(--text);background:var(--white);outline:none;transition:all .3s;-webkit-appearance:none;appearance:none}
.cf:focus{border-color:var(--coral);box-shadow:0 0 0 4px rgba(251,95,71,.12)}
.cf::placeholder{color:var(--muted-light)}
select.cf{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23FB5F47' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 20px center}
textarea.cf{resize:vertical;min-height:110px}
.intro-panel li{align-items:flex-start}
.intro-panel li svg{margin-top:5px}
@media(max-width:680px){.cf-row{grid-template-columns:1fr!important}}
