@charset "UTF-8";

/* ═══════════════════════════════════════
   DESIGN TOKENS
   ═══════════════════════════════════════ */
:root {
    --bg: #f8f7f4;
    --bg-2: transparent;
    --card: rgba(255,255,255,.03);
    --card-hover: rgba(255,255,255,.12);
    --border: rgba(255,255,255,.45);
    --border-hover: rgba(255,255,255,.8);
    --text: #1a1a1a;
    --text-2: #4a4a4a;
    --text-3: #7a7a7a;
    --accent: #ff5e00;
    --accent-soft: rgba(255,94,0,.1);
    --purple: #a855f7;
    --r: 20px;
    --font: 'Be Vietnam Pro', system-ui, -apple-system, sans-serif;
    --max: 1280px;
    --ease: cubic-bezier(.22,1,.36,1);
    --ease-out: cubic-bezier(.16,1,.3,1);
}


/* ═══════════════════════════════════════
   GLOBAL LIQUID GLASS FOR CARDS
   ═══════════════════════════════════════ */
.svc-card, .team-card, .step, .work-item, .news-card, .client-card, .aval, .faq-item {
    backdrop-filter: blur(28px) saturate(180%);
    -webkit-backdrop-filter: blur(28px) saturate(180%);
    box-shadow: 0 8px 32px rgba(0,0,0,0.04), 0 1px 0 rgba(255,255,255,0.6) inset;
    border-top-color: rgba(255,255,255,0.7);
    border-left-color: rgba(255,255,255,0.7);
}

/* ═══════════════════════════════════════
   RESET
   ═══════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-padding-top:96px}
body{font-family:var(--font);background:var(--bg);background-image:linear-gradient(135deg, rgba(255,255,255,0.4) 0%, rgba(248,247,244,0.3) 100%), url('background.png');background-size:100% 100%, cover;background-repeat:no-repeat, no-repeat;background-attachment:scroll, fixed;background-position:center, center;color:var(--text);line-height:1.6;overflow-x:hidden;text-wrap:pretty}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-weight:700;line-height:1.14;text-wrap:balance}
button{font-family:var(--font)}

/* ═══════════════════════════════════════
   UTILITIES
   ═══════════════════════════════════════ */
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 clamp(1.25rem,4vw,3rem)}
.center{text-align:center}

/* ═══════════════════════════════════════
   CUSTOM CURSOR (disabled for performance)
   ═══════════════════════════════════════ */
.cursor{display:none!important}

/* ═══════════════════════════════════════
   LOADER
   ═══════════════════════════════════════ */
.loader{position:fixed;inset:0;background:#f8f7f4;z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .8s var(--ease)}
.loader.done{opacity:0;pointer-events:none}
.loader-inner{text-align:center}
.loader-logo{margin-bottom:.5rem}
.loader-logo img{height:140px;filter:brightness(0);margin:0 auto}
.loader-bar{width:180px;height:1px;background:var(--border);margin:1.5rem auto;overflow:hidden}
.loader-fill{width:0;height:100%;background:var(--accent)}
.loader-sub{font-size:.75rem;letter-spacing:4px;text-transform:uppercase;color:var(--text-3)}

/* ═══════════════════════════════════════
   HEADER
   ═══════════════════════════════════════ */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:1.2rem 0;transition:all .4s var(--ease)}
.header.scrolled{background:rgba(255,255,255,.5);backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid var(--border)}
.nav{max-width:var(--max);margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem);display:flex;align-items:center;justify-content:space-between}
.nav-logo img{height:56px;filter:brightness(0);transition:opacity .3s}
.nav-logo img:hover{opacity:.7}
.nav-links{display:flex;gap:2.5rem}
.nav-links a{font-size:.8rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-2);transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--accent);transition:width .3s var(--ease)}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}
.nav-cta{font-size:.8rem;font-weight:600;padding:.65rem 1.6rem;border:1px solid var(--border);border-radius:100px;transition:all .4s var(--ease);letter-spacing:.5px}
.nav-cta:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:28px;height:18px;position:relative;z-index:1001}
.nav-toggle span{display:block;width:100%;height:1.5px;background:var(--text);position:absolute;left:0;transition:all .3s var(--ease)}
.nav-toggle span:first-child{top:0}
.nav-toggle span:last-child{bottom:0}
.nav-toggle.active span:first-child{top:50%;transform:rotate(45deg)}
.nav-toggle.active span:last-child{bottom:50%;transform:rotate(-45deg)}

/* ═══════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;max-width:100%;padding:1rem 2.2rem;border-radius:100px;font-size:.9rem;font-weight:600;font-family:var(--font);line-height:1.25;text-align:center;transition:all .4s var(--ease);cursor:pointer;border:none;position:relative;overflow:hidden}
.btn--primary{background:var(--accent);color:#fff}
.btn--primary::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.15));opacity:0;transition:opacity .4s}
.btn--primary:hover::before{opacity:1}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(255,94,0,.25)}
.btn--ghost{background:rgba(255,255,255,.45);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text);border:1px solid rgba(0,0,0,.08);border-top:1px solid rgba(255,255,255,.8);border-left:1px solid rgba(255,255,255,.8);box-shadow:0 4px 16px rgba(0,0,0,.06),0 1px 0 rgba(255,255,255,.7) inset}
.btn--ghost:hover{background:rgba(255,255,255,.7);border-color:rgba(0,0,0,.12);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.1),0 1px 0 rgba(255,255,255,.9) inset}
.btn--outline{background:rgba(255,255,255,.45);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text);border:1px solid rgba(0,0,0,.08);border-top:1px solid rgba(255,255,255,.8);border-left:1px solid rgba(255,255,255,.8);box-shadow:0 4px 16px rgba(0,0,0,.06),0 1px 0 rgba(255,255,255,.7) inset;width:100%;justify-content:center}
.btn--outline:hover{background:rgba(255,255,255,.7);border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,94,0,.12),0 1px 0 rgba(255,255,255,.9) inset}

/* ═══════════════════════════════════════
   HERO
   ═══════════════════════════════════════ */
.hero{min-height:100vh;display:flex;align-items:center;padding:clamp(6rem,10vh,8rem) 0 clamp(3rem,5vh,4rem);position:relative;overflow:hidden}

/* Decorative grid background */
.hero-grid-bg{position:absolute;inset:0;background-image:
    linear-gradient(rgba(0,0,0,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px);
    background-size:80px 80px;
    mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 30%,transparent 80%);
    -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 30%,transparent 80%);
    opacity:.6}

/* Gradient orbs */
.orb{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none}
.orb--1{width:600px;height:600px;background:rgba(255,94,0,.12);top:-200px;right:-100px;animation:float 8s ease-in-out infinite}
.orb--2{width:400px;height:400px;background:rgba(168,85,247,.1);bottom:-100px;left:-100px;animation:float 10s ease-in-out infinite reverse}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-30px)}}

.hero-inner{display:grid;grid-template-columns:1.1fr 0.9fr;gap:clamp(3rem,6vw,5rem);align-items:center;position:relative;z-index:2;width:100%}
.hero-content{max-width:680px;padding-right:2rem}
.hero-label{font-size:.85rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem;display:inline-flex;align-items:center;gap:.8rem;background:var(--accent-soft);padding:.5rem 1rem;border-radius:100px}
.hero-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.hero-title{font-size:clamp(3.2rem,5vw,4.5rem);font-weight:800;margin-bottom:1.5rem;letter-spacing:-1px;line-height:1.1}
.hero-line{display:block}
.hero-title em{font-style:normal;color:var(--accent)}
.text-stroke{color:#0f3460;-webkit-text-stroke:0;background:linear-gradient(135deg,#0f3460 0%,#1a1a6e 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 6px rgba(15,52,96,.15))}
.hero-sub{font-size:clamp(1rem,1.1vw,1.15rem);color:var(--text-2);max-width:560px;margin-bottom:2.5rem;line-height:1.8}
.hero-actions{display:flex;gap:1.2rem;flex-wrap:wrap}

/* Hero visual */
.hero-visual{position:relative;width:100%;aspect-ratio:1/1;max-height:75vh;display:flex;align-items:center;justify-content:center}
.hero-illustration {position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.hero-illus-bg {position:absolute;width:130%;max-width:none;left:50%;top:50%;transform:translate(-50%, -50%);z-index:-1}
.hero-illus-main {position:relative;z-index:2;width:90%;max-width:600px;object-fit:contain;animation:gentleFloat 6s ease-in-out infinite alternate}
@keyframes gentleFloat{0%{transform:translateY(0)}100%{transform:translateY(-15px)}}

.hero-illus-float {position:absolute;z-index:3}
.hero-illus-float--1 {top:2%;right:0%;width:clamp(160px,15vw,220px);animation:cardFloat 6s ease-in-out infinite;z-index:1}
.hero-illus-float--2 {bottom:20%;left:-2%;width:clamp(90px,10vw,130px);animation:cardFloat 5s ease-in-out infinite reverse}
@keyframes cardFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}

/* Stats Card - In flow */
.hero-stats-card{display:flex;align-items:center;gap:clamp(1rem,2vw,1.5rem);margin-bottom:2rem;flex-wrap:wrap}
.stat-item{display:flex;flex-direction:column;align-items:flex-start;position:relative}
.stat-val{display:flex;align-items:baseline}
.stat-item strong{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:800;color:var(--text);line-height:1}
.stat-item .suffix{font-size:clamp(1.2rem,2vw,1.5rem);font-weight:800;color:var(--accent)}
.stat-item .label{font-size:.7rem;color:var(--text-3);text-transform:uppercase;letter-spacing:1px;font-weight:600;margin-top:.3rem}
.stat-divider{width:1px;height:30px;background:var(--border)}

/* Scroll indicator */
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:5}
.scroll-line{width:1px;height:40px;background:linear-gradient(180deg,var(--accent),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%{opacity:1;transform:scaleY(1)}50%{opacity:.3;transform:scaleY(.6)}100%{opacity:1;transform:scaleY(1)}}
.hero-scroll span{font-size:.65rem;letter-spacing:3px;text-transform:uppercase;color:var(--text-3)}

/* ═══════════════════════════════════════
   MARQUEE
   ═══════════════════════════════════════ */
.marquee{padding:1.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden}
.marquee-track{display:flex;animation:scroll 30s linear infinite;width:max-content;gap:1.5rem;align-items:center}
.marquee-track span{font-size:clamp(1rem,2vw,1.5rem);font-weight:800;text-transform:uppercase;letter-spacing:4px;color:var(--text-3);white-space:nowrap}
.marquee-track .sep{font-size:.6rem;color:var(--accent);opacity:.5}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════
   SECTION HEAD
   ═══════════════════════════════════════ */
.section-head{margin-bottom:clamp(1rem,2vh,2rem)}
.section-label{font-size:.75rem;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--text-3);margin-bottom:1rem}
.section-title{font-size:clamp(1.5rem,2.8vw,2.5rem);font-weight:800;letter-spacing:0}
.section-desc{font-size:clamp(.85rem,1vw,.95rem);color:var(--text-2);margin-top:1rem;max-width:620px;line-height:1.75}
.center .section-desc{margin-left:auto;margin-right:auto}

/* ═══════════════════════════════════════
   SERVICES
   ═══════════════════════════════════════ */
.services{padding:clamp(2rem,4vh,4rem) 0;min-height:100vh;display:flex;align-items:center}
.services .container{width:100%}
.services-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.svc-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:clamp(1.2rem,2vw,1.8rem);position:relative;overflow:hidden;transition:all .5s var(--ease);cursor:pointer}
.svc-card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--mouse-x,50%) var(--mouse-y,50%),var(--accent-soft),transparent 60%);opacity:0;transition:opacity .5s}
.svc-card:hover::before{opacity:1}
.svc-card:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.svc-icon{margin-bottom:1.5rem;color:var(--accent);position:relative}
.svc-num{position:absolute;top:.5rem;right:0;font-size:3.5rem;font-weight:900;color:rgba(255,255,255,.02);line-height:1}
.svc-card h3{font-size:1.3rem;margin-bottom:.8rem;position:relative}
.svc-card p{color:var(--text-2);font-size:.9rem;line-height:1.7;margin-bottom:1.5rem;position:relative}
.svc-tags{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;position:relative}
.svc-tags span{font-size:.7rem;padding:.35rem .5rem;border:1px solid var(--border);border-radius:100px;color:var(--text-3);transition:all .3s;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.svc-card:hover .svc-tags span{border-color:var(--border-hover);color:var(--text-2)}
.svc-arrow{position:absolute;bottom:2rem;right:2rem;font-size:1.2rem;color:var(--text-3);transition:all .4s var(--ease);opacity:0;transform:translateX(-8px)}
.svc-card:hover .svc-arrow{opacity:1;transform:translateX(0);color:var(--accent)}

/* ═══════════════════════════════════════
   PORTFOLIO / WORK
   ═══════════════════════════════════════ */
.work{padding:clamp(2rem,4vh,4rem) 0;background:var(--bg-2)}
.work-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.work-item--wide{grid-column:1/-1}
.work-item{border-radius:var(--r);overflow:hidden;background:var(--card);border:1px solid var(--border);transition:all .5s var(--ease);cursor:pointer}
.work-item:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.work-img{position:relative;overflow:hidden}
.work-img img{width:100%;height:320px;object-fit:cover;transition:transform .8s var(--ease)}
.work-item:hover .work-img img{transform:scale(1.05)}
.work-item--wide .work-img img{height:400px}
.work-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(255,255,255,.92));display:flex;align-items:flex-end;justify-content:space-between;padding:1.5rem;opacity:0;transition:opacity .4s}
.work-item:hover .work-overlay{opacity:1}
.work-cat{font-size:.7rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:.4rem .8rem;border-radius:100px}
.work-link{font-size:.85rem;color:var(--text);font-weight:500}
.work-info{padding:1.5rem 2rem 2rem}
.work-info h3{font-size:1.2rem;margin-bottom:.4rem}
.work-info > p{font-size:.85rem;color:var(--text-2);margin-bottom:1.2rem}
.work-results{display:flex;gap:clamp(1rem,3vw,2rem);flex-wrap:wrap}
.work-metric{display:flex;flex-direction:column}
.work-metric strong{font-size:1.3rem;font-weight:800;color:var(--accent)}
.work-metric span{font-size:.7rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px}

/* ═══════════════════════════════════════
   STATS
   ═══════════════════════════════════════ */
.stats{padding:clamp(3rem,6vw,5rem) 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.stat{text-align:center;padding:1.5rem}
.stat-num{font-size:clamp(2rem,4vw,2.8rem);font-weight:800;color:var(--text);display:inline}
.stat-suffix{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;color:var(--accent)}
.stat p{font-size:.8rem;color:var(--text-3);margin-top:.5rem;text-transform:uppercase;letter-spacing:1.5px}

/* ═══════════════════════════════════════
   CLIENTS
   ═══════════════════════════════════════ */
.clients{padding:clamp(4rem,7vw,6rem) 0;background:var(--bg-2)}
.clients-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.client-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:1.5rem;text-align:center;transition:all .4s var(--ease);display:flex;flex-direction:column;align-items:center;gap:.3rem}
.client-card:hover{border-color:var(--border-hover);transform:translateY(-3px)}
.client-name{font-size:.95rem;font-weight:700;color:var(--text)}
.client-card small{font-size:.75rem;color:var(--text-3)}

/* ═══════════════════════════════════════
   TEAM
   ═══════════════════════════════════════ */
.team{padding:clamp(2rem,4vh,4rem) 0;min-height:100vh;display:flex;align-items:center}
.team .container{width:100%}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.team-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;text-align:center;transition:all .5s var(--ease)}
.team-card:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.team-ava{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--purple));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;margin:0 auto 1.2rem}
.team-card h3{font-size:1.1rem;margin-bottom:.3rem}
.team-role{font-size:.8rem;color:var(--accent);font-weight:600;margin-bottom:.8rem;text-transform:uppercase;letter-spacing:1px}
.team-bio{font-size:.85rem;color:var(--text-2);line-height:1.6}

/* ═══════════════════════════════════════
   PROCESS
   ═══════════════════════════════════════ */
.process{padding:clamp(2rem,4vh,4rem) 0;min-height:100vh;display:flex;align-items:center}
.process .container{width:100%}
.process-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}
.step{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:clamp(1.2rem,2vw,1.5rem);transition:all .5s var(--ease);cursor:default}
.step:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.step-top{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}
.step-num{font-size:.8rem;font-weight:700;color:var(--accent);letter-spacing:2px;flex-shrink:0}
.step-line{flex-grow:1;height:1px;background:var(--border)}
.step h3{font-size:1.05rem;margin-bottom:.6rem}
.step p{font-size:.85rem;color:var(--text-2);line-height:1.7}

/* ═══════════════════════════════════════
   ABOUT
   ═══════════════════════════════════════ */
.about{padding:clamp(2rem,4vh,4rem) 0;border-top:1px solid var(--border);min-height:100vh;display:flex;align-items:center}
.about .container{width:100%}
.about-layout{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:clamp(2.5rem,6vw,5rem);align-items:start}
.about-left .section-title{position:relative}
.about-lead{font-size:1.1rem;line-height:1.8;margin-bottom:2.5rem;color:var(--text-2)}
.about-vals{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.aval{padding:1.5rem;border:1px solid var(--border);border-radius:14px;transition:all .4s var(--ease)}
.aval:hover{border-color:var(--border-hover);background:var(--card)}
.aval h4{font-size:.95rem;margin-bottom:.4rem;color:var(--accent)}
.aval p{font-size:.85rem;color:var(--text-2);line-height:1.6}

/* ═══════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════ */
.testi{padding:clamp(2rem,4vh,4rem) 0;background:var(--bg-2);overflow:hidden;min-height:100vh;display:flex;align-items:center}
.testi .container{width:100%}

/* Carousel wrapper */
.testi-carousel{position:relative}
.testi-track-wrap{overflow:hidden;border-radius:var(--r);margin:0}
.testi-track{--testi-gap:1.5rem;display:flex;gap:var(--testi-gap);transition:transform .6s var(--ease);padding:1rem;will-change:transform}
.testi-card{background:rgba(255,255,255,.05);backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);border:1px solid rgba(255,255,255,.4);border-top:1px solid rgba(255,255,255,.95);border-left:1px solid rgba(255,255,255,.95);border-radius:var(--r);padding:clamp(1.5rem,3vw,2.5rem);flex:0 0 calc((100% - var(--testi-gap)) / 2);min-width:0;transition:all .5s var(--ease);box-shadow:0 8px 32px rgba(0,0,0,.04),0 1px 0 rgba(255,255,255,.9) inset}
.testi-card:hover{box-shadow:0 20px 60px rgba(0,0,0,.12),0 1px 0 rgba(255,255,255,1) inset;transform:translateY(-4px)}
.testi-card--feat{border-color:var(--accent);background:rgba(255,94,0,.03)}
.testi-stars{color:var(--accent);font-size:1rem;letter-spacing:2px;margin-bottom:1.2rem}
.testi-card p{font-size:.95rem;line-height:1.8;color:var(--text-2);margin-bottom:1.5rem;font-style:italic}
.testi-card footer{display:flex;align-items:center;gap:.8rem}
.testi-ava{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--purple));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}
.testi-card footer strong{font-size:.9rem}
.testi-card footer small{color:var(--text-3);font-size:.75rem}

/* Carousel navigation */
.testi-nav{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2.5rem}
.testi-btn{width:48px;height:48px;border-radius:50%;border:1px solid rgba(0,0,0,.08);background:rgba(255,255,255,.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease);color:var(--text);font-size:1.1rem;box-shadow:0 4px 16px rgba(0,0,0,.06)}
.testi-btn:hover{background:rgba(255,255,255,.9);transform:scale(1.08);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.testi-dots{display:flex;gap:.5rem}
.testi-dot{width:8px;height:8px;border-radius:50%;background:rgba(0,0,0,.12);border:none;cursor:pointer;transition:all .3s var(--ease);padding:0}
.testi-dot.active{background:var(--accent);width:24px;border-radius:4px}

/* ═══════════════════════════════════════
   PRICING
   ═══════════════════════════════════════ */
.pricing{padding:clamp(2rem,4vh,4rem) 0;min-height:100vh;display:flex;align-items:center}
.pricing .container{width:100%}
.pricing-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(1.25rem,2.2vw,1.8rem);align-items:stretch}
.price-card{min-height:auto;background:linear-gradient(145deg,rgba(255,255,255,.3),rgba(255,255,255,.15) 42%,rgba(255,255,255,.25)) !important;backdrop-filter:blur(34px) saturate(165%) contrast(1.02) !important;-webkit-backdrop-filter:blur(34px) saturate(165%) contrast(1.02) !important;border:1px solid rgba(255,255,255,.58) !important;border-right-color:rgba(0,0,0,.08) !important;border-bottom-color:rgba(0,0,0,.08) !important;border-radius:18px;padding:clamp(1.2rem,2vw,1.5rem);display:flex;flex-direction:column;position:relative;overflow:visible;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease) !important;box-shadow:0 28px 70px rgba(20,20,20,.11),0 2px 8px rgba(255,255,255,.75) inset,0 -22px 48px rgba(255,255,255,.28) inset !important}
.price-card:hover{box-shadow:0 38px 90px rgba(20,20,20,.16),0 2px 10px rgba(255,255,255,.86) inset,0 -22px 48px rgba(255,255,255,.34) inset !important;transform:translateY(-10px)}
.price-card--pop{border-color:rgba(255,94,0,.42) !important;background:linear-gradient(145deg,rgba(255,255,255,.4),rgba(255,247,242,.25) 45%,rgba(255,255,255,.35)) !important;transform:translateY(-14px);box-shadow:0 34px 90px rgba(255,94,0,.18),0 28px 70px rgba(20,20,20,.1),0 2px 8px rgba(255,255,255,.82) inset !important}
.price-card--pop:hover{transform:translateY(-22px)}
.price-badge{position:absolute;top:-16px;left:50%;transform:translateX(-50%);white-space:nowrap;background:linear-gradient(135deg,#ff5e00,#ff8a3d);color:#fff;padding:.55rem 1.5rem;border-radius:100px;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:1.4px;text-align:center;box-shadow:0 8px 24px rgba(255,94,0,.3);z-index:5}
.price-card--pop{padding-top:clamp(1.75rem,2.4vw,2.35rem)}
.price-card h3{font-size:1.18rem;font-weight:800;color:var(--text);margin-bottom:.55rem;text-align:center}
.price-target{text-align:center;min-height:2.8rem;display:flex;align-items:center;justify-content:center}
.price-val{font-size:clamp(2rem,3.5vw,2.8rem);font-weight:900;margin:.75rem 0 .6rem;text-align:center;background:linear-gradient(135deg,#612706,#b74300 58%,#ff5e00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.price-val span{font-size:.85rem;font-weight:400;-webkit-text-fill-color:var(--text-3)}
.price-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem;margin:1rem 0 1.25rem}
.price-meta span{border:1px solid rgba(255,255,255,.58);border-right-color:rgba(0,0,0,.07);border-bottom-color:rgba(0,0,0,.07);border-radius:10px;padding:.62rem .7rem;background:linear-gradient(145deg,rgba(255,255,255,.56),rgba(255,255,255,.28));backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);font-size:.72rem;font-weight:800;color:var(--text-2);line-height:1.2;text-align:center;box-shadow:0 8px 18px rgba(0,0,0,.04),0 1px 0 rgba(255,255,255,.78) inset}
.price-card ul{margin:0 0 2rem;flex:1;padding-top:1.55rem;border-top:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;gap:.08rem}
.price-card li{padding:.48rem 0;font-size:.87rem;color:var(--text-2);display:flex;align-items:flex-start;gap:.7rem;line-height:1.55}
.price-card li::before{content:'✦';color:var(--accent);font-size:.55rem;margin-top:.3rem;flex-shrink:0}
.price-card .btn{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}

/* ═══════════════════════════════════════
   NEWS
   ═══════════════════════════════════════ */
.news{padding:clamp(2rem,4vh,4rem) 0;background:var(--bg-2)}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.news-card{border-radius:var(--r);overflow:hidden;background:var(--card);border:1px solid var(--border);transition:all .5s var(--ease);cursor:pointer}
.news-card:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.news-thumb{height:200px;overflow:hidden}
.news-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.news-card:hover .news-thumb img{transform:scale(1.08)}
.news-body{padding:1.5rem}
.news-tag{font-size:.65rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:.8rem;display:inline-block;background:var(--accent-soft);padding:.3rem .6rem;border-radius:4px}
.news-body h3{font-size:1.05rem;margin-bottom:.5rem;line-height:1.4}
.news-body p{font-size:.8rem;color:var(--text-2);line-height:1.6}

/* ═══════════════════════════════════════
   CTA
   ═══════════════════════════════════════ */
.cta{padding:clamp(5rem,10vw,10rem) 0;text-align:center;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;background:var(--accent-soft);border-radius:50%;filter:blur(120px);transform:translate(-50%,-50%);pointer-events:none}
.cta-inner{position:relative;z-index:1}
.cta-title{font-size:clamp(2.5rem,6vw,5rem);font-weight:800;margin:.5rem 0 1rem}
.cta-title em{font-style:normal;color:var(--accent)}
.cta-desc{font-size:1.05rem;color:var(--text-2);margin-bottom:2.5rem;max-width:500px;margin-left:auto;margin-right:auto}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ═══════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════ */
.footer{padding:6rem 0 3rem;border-top:1px solid var(--border)}
.footer-top{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-bottom:4rem;align-items:center}
.footer-brand-logo{height:clamp(60px,8vw,100px);object-fit:contain;filter:brightness(0)}
.footer-tagline{font-size:1rem;color:var(--text-2);line-height:1.7}
.footer-mid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;padding-top:3rem;border-top:1px solid var(--border);margin-bottom:3rem}
.footer-col{display:flex;flex-direction:column;gap:.6rem}
.footer-col h4{font-size:.7rem;text-transform:uppercase;letter-spacing:2.5px;color:var(--text-3);margin-bottom:.5rem}
.footer-col a,.footer-col p{font-size:.85rem;color:var(--text-2);transition:color .3s}
.footer-col a:hover{color:var(--text)}
.footer-bottom{color:var(--text-3);font-size:.75rem;padding-top:2rem;border-top:1px solid var(--border)}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
@media(max-width:1024px){
    .hero-inner{grid-template-columns:1fr;text-align:center;gap:3rem}
    .hero-content{max-width:100%;padding-right:0}
    .hero-sub{margin-left:auto;margin-right:auto}
    .hero-actions{justify-content:center}
    .hero-visual{max-width:600px;margin:0 auto;max-height:60vh;flex-direction:column;gap:2rem}
    .hero-stats-card{justify-content:center}
    .about-layout{grid-template-columns:1fr}
    .about-left .section-title{position:static}
    .process-grid{grid-template-columns:repeat(2,1fr)}
    .pricing-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .price-card--pop{transform:none}
    .price-card--pop:hover{transform:translateY(-8px)}
    .testi-grid{grid-template-columns:1fr}
    .stats-row{grid-template-columns:repeat(2,1fr)}
    .footer-top{grid-template-columns:1fr}
    .work-grid{grid-template-columns:1fr}
    .news-grid{grid-template-columns:1fr}
    .footer-mid{grid-template-columns:repeat(2,1fr)}
    .clients-grid{grid-template-columns:repeat(2,1fr)}
    .team-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
    body{background-attachment:scroll;background-size:420px 420px}
    .header{padding:.8rem 0}
    .nav-logo img{height:46px}
    .nav-links,.nav-cta{display:none}
    .nav-toggle{display:block}
    .nav-links.open{display:flex;flex-direction:column;position:fixed;inset:0;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);z-index:999;align-items:center;justify-content:center;gap:2rem}
    .nav-links.open a{font-size:1.2rem}
    .cursor{display:none}
    .hero{padding:6.5rem 0 3rem;min-height:auto}
    .hero-title{font-size:clamp(2.05rem,10vw,3rem)}
    .hero-line{display:inline}
    .hero-sub{line-height:1.7;margin-bottom:1.5rem}
    .hero-actions{width:100%}
    .hero-actions .btn{width:100%}
    .hero-visual{max-width:min(420px,100%)}
    .hero-img-wrap{aspect-ratio:4/3;max-height:none}
    .hero-scroll{display:none}
    .hero-float-card{display:none}
    .services,.process,.about,.testi,.pricing,.news,.work{padding:4.5rem 0}
    .section-title br,.cta-title br{display:block}
    .section-title{font-size:clamp(1.75rem,8vw,2.35rem)}
    .section-desc{max-width:100%}
    .process-grid{grid-template-columns:1fr}
    .about-vals{grid-template-columns:1fr}
    .cta{padding:5rem 0}
    .footer-mid{grid-template-columns:1fr}
    .cta-actions,.hero-actions{flex-direction:column;align-items:center}
    .cta-actions .btn{width:100%}
    .services-grid{grid-template-columns:1fr}
    .work-info{padding:1.25rem}
    .work-img img,.work-item--wide .work-img img{height:260px}
    .work-results{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
    .stats-row{grid-template-columns:1fr}
    .clients-grid{grid-template-columns:1fr}
    .team-grid{grid-template-columns:1fr}
    .team,.clients{padding:4rem 0}
    .faq,.news{padding:5rem 0}
    .footer-mid{grid-template-columns:1fr}
    .hero-stats-card{flex-direction:column;align-items:center;gap:1rem}
    .stat-divider{width:40px;height:1px;background:linear-gradient(to right,transparent,var(--accent),transparent)}
    .footer-bottom{flex-direction:column}
    .testi-track{--testi-gap:1rem;padding:.75rem}
    .testi-card{flex-basis:100%}
    .testi-card footer{align-items:flex-start}
    .pricing-grid{grid-template-columns:1fr}
    .price-card{min-height:auto}
    .price-meta{grid-template-columns:1fr 1fr}
    .price-card .btn{width:100%}
    .news-grid{grid-template-columns:1fr}
    .footer{padding:4rem 0 2rem}
}

@media(max-width:480px){
    .container{padding:0 1rem}
    .btn{padding:.9rem 1.2rem;width:100%}
    .hero-label{font-size:.68rem;letter-spacing:1.2px;margin-bottom:1.25rem}
    .hero-trust{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:start;text-align:left;gap:.75rem}
    .trust-divider{display:none}
    .svc-card,.step,.team-card,.price-card,.testi-card,.news-body,.faq-item summary{padding:1.25rem}
    .price-meta{grid-template-columns:1fr}
    .faq-answer{padding:0 1.25rem 1.25rem}
    .footer-top{gap:2rem;margin-bottom:2.5rem}
}

@media(max-height:760px) and (min-width:769px){
    .hero{min-height:auto;padding-top:7rem}
    .hero-img-wrap{max-height:460px}
    .hero-scroll{display:none}
}

/* ═══════════════════════════════════════
   ANIMATIONS (Initial states for GSAP)
   ═══════════════════════════════════════ */
/* ═══════════════════════════════════════
   HERO TRUST BADGES
   ═══════════════════════════════════════ */
.hero-trust{display:flex;align-items:center;gap:1.5rem;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border)}
.trust-item{display:flex;flex-direction:column}
.trust-item strong{font-size:1.3rem;font-weight:800;color:var(--accent)}
.trust-item span{font-size:.7rem;color:var(--text-3);text-transform:uppercase;letter-spacing:1px}
.trust-divider{width:1px;height:30px;background:var(--border)}

/* ═══════════════════════════════════════
   ABOUT QUOTE
   ═══════════════════════════════════════ */
.about-quote{font-size:1rem;color:var(--text-2);font-style:italic;margin-top:1.5rem;padding-left:1.5rem;border-left:2px solid var(--accent);line-height:1.8;position:relative;z-index:1}

/* ═══════════════════════════════════════
   PRICING TARGET
   ═══════════════════════════════════════ */
.price-target{font-size:.8rem;color:var(--text-3);margin-bottom:1rem;line-height:1.5}

/* ═══════════════════════════════════════
   NEWS DATE
   ═══════════════════════════════════════ */
.news-date{font-size:.7rem;color:var(--text-3);margin-top:.8rem;display:block}

/* ═══════════════════════════════════════
   FAQ
   ═══════════════════════════════════════ */
.faq{padding:clamp(2rem,4vh,4rem) 0}
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:.5rem}
.faq-item{background:var(--card);border:1px solid var(--border);border-radius:14px;transition:all .4s var(--ease);overflow:hidden}
.faq-item:hover{border-color:var(--border-hover)}
.faq-item[open]{border-color:var(--accent);background:rgba(255,94,0,.02)}
.faq-item summary{padding:1.3rem 1.8rem;font-size:.95rem;font-weight:600;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;transition:color .3s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:1.2rem;color:var(--accent);font-weight:300;transition:transform .3s var(--ease)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item[open] summary{color:var(--accent)}
.faq-answer{padding:0 1.8rem 1.5rem}
.faq-answer p{font-size:.9rem;color:var(--text-2);line-height:1.8}

/* ═══════════════════════════════════════
   CTA NOTE
   ═══════════════════════════════════════ */
.cta-note{font-size:.8rem;color:var(--text-3);margin-top:1.5rem}

/* ═══════════════════════════════════════
   FOOTER 4-COL & BOTTOM
   ═══════════════════════════════════════ */
.footer-mid{grid-template-columns:repeat(4,1fr)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}

/* ═══════════════════════════════════════
   SCROLL REVEAL (IntersectionObserver)
   ═══════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.revealed{opacity:1!important;transform:translateY(0)!important}

/* ═══════════════════════════════════════
   LIQUID GLASS OVERRIDES
   ═══════════════════════════════════════ */

/* Warm decorative blobs — visible on paper texture */
body::before, body::after {
    content: '';
    position: fixed;
    filter: blur(140px);
    z-index: -1;
    border-radius: 50%;
    animation: float 12s ease-in-out infinite alternate;
    pointer-events: none;
}
body::before {
    top: -10%; left: -5%; width: 500px; height: 500px;
    background: rgba(255, 94, 0, 0.08);
}
body::after {
    bottom: -10%; right: -5%; width: 600px; height: 600px;
    background: rgba(168, 85, 247, 0.06);
    animation-delay: -6s;
}

/* Glass card styling — frosted white on paper texture */
.svc-card, .work-item, .team-card, .step, .testi-card, .price-card, .news-card, .client-card, .aval, .faq-item {
    background: rgba(255,255,255,.3) !important;
    backdrop-filter: blur(20px) saturate(130%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(130%) !important;
    border: 1px solid rgba(0,0,0,.06) !important;
    border-top: 1px solid rgba(255,255,255,.95) !important;
    border-left: 1px solid rgba(255,255,255,.95) !important;
    box-shadow: 0 8px 32px rgba(0,0,0,.08), 0 1px 0 rgba(255,255,255,.9) inset !important;
    transform-style: preserve-3d;
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.4s ease, border-color 0.4s ease !important;
    will-change: transform, box-shadow;
    position: relative;
}

/* Warm accent spotlight on hover */
.svc-card::after, .work-item::after, .team-card::after, .step::after, .testi-card::after, .price-card::after, .news-card::after, .client-card::after, .aval::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: radial-gradient(
      600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
      rgba(255,94,0,.05),
      transparent 40%
    );
    z-index: 0;
    opacity: 0;
    transition: opacity 0.5s ease;
    pointer-events: none;
}

.svc-card > *, .work-item > *, .team-card > *, .step > *, .testi-card > *, .price-card > *, .news-card > *, .client-card > *, .aval > * {
    position: relative;
    z-index: 2;
}

.svc-card:hover, .work-item:hover, .team-card:hover, .step:hover, .testi-card:hover, .price-card:hover, .news-card:hover, .client-card:hover, .aval:hover, .faq-item:hover {
    box-shadow: 0 20px 60px rgba(0,0,0,.12), 0 1px 0 rgba(255,255,255,1) inset !important;
    border-color: rgba(0,0,0,.1) !important;
}

.svc-card:hover::after, .work-item:hover::after, .team-card:hover::after, .step:hover::after, .testi-card:hover::after, .price-card:hover::after, .news-card:hover::after, .client-card:hover::after, .aval:hover::after {
    opacity: 1;
}

/* Fix z-indexes for images inside glass cards */
.work-img img, .news-thumb img {
    position: relative;
    z-index: 1;
}

@media(max-width:1180px){
    .nav-links{gap:1.4rem}
    .nav-cta{padding:.6rem 1.1rem}
}

@media(max-width:1024px){
    .footer-mid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media(max-width:768px){
    .footer-mid{grid-template-columns:1fr}
}

/* Final pricing polish: stronger liquid glass and balanced card rhythm */
.price-card::before{
    content:'';
    position:absolute;
    inset:0;
    z-index:1;
    border-radius:inherit;
    background:
        linear-gradient(120deg,rgba(255,255,255,.3),rgba(255,255,255,0) 34%),
        linear-gradient(300deg,rgba(255,255,255,.1),rgba(255,255,255,0) 48%);
    opacity:.72;
    pointer-events:none;
}

.price-card::after{
    background:
        radial-gradient(420px circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(255,255,255,.72),rgba(255,94,0,.14) 28%,transparent 62%),
        radial-gradient(700px circle at 50% 115%,rgba(255,94,0,.08),transparent 58%) !important;
    opacity:.42;
}

.price-card:hover::after{opacity:.9}
.price-card .price-badge{position:absolute;top:1rem;left:1.6rem;right:1.6rem;transform:none;z-index:3}
.price-card li::before{content:'✦';color:var(--accent);font-size:.58rem;margin-top:.35rem;flex-shrink:0;text-shadow:0 0 14px rgba(255,94,0,.35)}
.price-card .btn{margin-top:auto;min-height:52px;border-radius:16px;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 16px 34px rgba(0,0,0,.08),0 1px 0 rgba(255,255,255,.78) inset}
.price-card .btn--outline{background:linear-gradient(145deg,rgba(255,255,255,.7),rgba(255,255,255,.32));border-color:rgba(255,255,255,.66);color:var(--text)}

@media(max-width:1024px){
    .price-card{min-height:auto}
}

@media(max-width:768px){
    .price-card{min-height:auto}
    .price-card--pop{padding-top:5.8rem}
    .price-card .price-badge{left:1.25rem;right:1.25rem}
}

/* Pricing v7: match liquid-glass reference */
.pricing{
    position:relative;
    isolation:isolate;
    overflow:hidden;
    padding:clamp(3rem,4vw,4rem) 0 clamp(3rem,4vw,4rem);
    background:transparent;
}

.pricing .container{
    position:relative;
    z-index:1;
}

.pricing .section-head{
    margin-bottom:clamp(1.5rem,2.5vw,2.5rem);
}

.pricing .section-title{
    font-size:clamp(2.2rem,4vw,3.6rem);
    line-height:1;
    letter-spacing:0;
    max-width:760px;
    margin:0 auto .5rem;
}

.pricing .section-desc{
    max-width:720px;
    font-size:clamp(0.95rem,1.2vw,1.05rem);
    line-height:1.5;
    color:#202020;
}

.pricing-grid{
    max-width:1220px;
    margin:0 auto;
    gap:clamp(1.05rem,2vw,1.5rem);
}

.pricing .price-card{
    min-height:auto;
    padding:2rem clamp(1.5rem,2.5vw,2rem) 1.5rem;
    border-radius:26px;
    background:
        radial-gradient(ellipse at 22% 10%,rgba(255,255,255,.15),rgba(255,255,255,.05) 34%,transparent 62%),
        radial-gradient(ellipse at 80% 92%,rgba(255,255,255,.1),rgba(255,255,255,.02) 26%,transparent 54%),
        linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.02) 48%,rgba(255,255,255,.1)) !important;
    border:1px solid rgba(255,255,255,.72) !important;
    border-right-color:rgba(0,0,0,.08) !important;
    border-bottom-color:rgba(0,0,0,.08) !important;
    backdrop-filter:blur(42px) saturate(180%) brightness(1.04) !important;
    -webkit-backdrop-filter:blur(42px) saturate(180%) brightness(1.04) !important;
    box-shadow:
        0 34px 90px rgba(37,28,20,.12),
        0 1px 0 rgba(255,255,255,.9) inset,
        0 24px 60px rgba(255,255,255,.42) inset,
        0 -26px 50px rgba(255,255,255,.22) inset !important;
}

.pricing .price-card::before{
    z-index:1;
    background:
        linear-gradient(128deg,rgba(255,255,255,.82),rgba(255,255,255,0) 31%),
        linear-gradient(292deg,rgba(255,255,255,.38),rgba(255,255,255,0) 42%),
        radial-gradient(circle at 88% 12%,rgba(255,255,255,.7),transparent 26%);
    opacity:.86;
}

.pricing .price-card::after{
    z-index:0;
    background:
        radial-gradient(420px circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(255,255,255,.95),rgba(255,94,0,.15) 32%,transparent 65%),
        radial-gradient(ellipse at 50% 118%,rgba(255,94,0,.09),transparent 55%) !important;
    opacity:.58;
}

.pricing .price-card:hover{
    transform:translateY(-12px);
    border-color:rgba(255,255,255,.88) !important;
    box-shadow:
        0 46px 110px rgba(37,28,20,.17),
        0 1px 0 rgba(255,255,255,1) inset,
        0 28px 64px rgba(255,255,255,.48) inset,
        0 0 46px rgba(255,94,0,.08) !important;
}

.pricing .price-card--pop{
    min-height:auto;
    padding-top:2rem;
    transform:translateY(-12px);
    border-color:rgba(255,122,40,.58) !important;
    box-shadow:
        0 0 0 1px rgba(255,122,40,.24),
        0 42px 110px rgba(255,94,0,.2),
        0 34px 90px rgba(37,28,20,.12),
        0 1px 0 rgba(255,255,255,.9) inset,
        0 -26px 54px rgba(255,117,34,.08) inset !important;
}

.pricing .price-card--pop:hover{
    transform:translateY(-22px);
    box-shadow:
        0 0 0 1px rgba(255,122,40,.34),
        0 50px 125px rgba(255,94,0,.24),
        0 40px 100px rgba(37,28,20,.14),
        0 1px 0 rgba(255,255,255,1) inset !important;
}

.pricing .price-badge{
    position:absolute;
    top:-16px;
    left:50%;
    right:auto;
    width:auto;
    height:auto;
    transform:translateX(-50%);
    padding:.55rem 1.5rem;
    border-radius:100px;
    background:linear-gradient(135deg,#ff5e00,#ff8a3d);
    color:#fff;
    font-size:.7rem;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:1.4px;
    text-align:center;
    box-shadow:0 8px 24px rgba(255,94,0,.3);
    z-index:5;
    white-space:nowrap;
}

.pricing .price-badge::before,
.pricing .price-badge::after{
    display:none;
}

.pricing .price-card h3{
    font-size:clamp(1.15rem,1.5vw,1.35rem);
    margin-bottom:.5rem;
}

.pricing .price-target{
    min-height:auto;
    max-width:250px;
    margin:0 auto 1rem;
    color:#222;
    font-size:.85rem;
    line-height:1.5;
}

.pricing .price-val{
    margin:0 0 1rem;
    font-size:clamp(2.5rem,4vw,3.2rem);
    line-height:1;
    letter-spacing:0;
}

.pricing .price-val span{
    margin-left:.28rem;
    font-size:.92rem;
    font-weight:800;
    -webkit-text-fill-color:#a9440a;
}

.pricing .price-meta{
    gap:.5rem;
    margin:0 0 1rem;
}

.pricing .price-meta span{
    min-height:36px;
    border-radius:11px;
    background:linear-gradient(180deg,rgba(255,255,255,.78),rgba(255,255,255,.48));
    box-shadow:
        0 12px 26px rgba(38,30,24,.08),
        0 1px 0 rgba(255,255,255,.92) inset;
    border:1px solid rgba(255,255,255,.82);
    border-right-color:rgba(0,0,0,.05);
    border-bottom-color:rgba(0,0,0,.06);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:.75rem;
}

.pricing .price-card ul{
    flex:1;
    gap:.3rem;
    padding-top:1rem;
    border-top:1px solid rgba(0,0,0,.08);
}

.pricing .price-card li{
    padding:.1rem 0;
    gap:.6rem;
    color:#1f1f1f;
    font-size:.85rem;
    line-height:1.4;
}

.pricing .price-card li::before{
    content:'';
    width:5px;
    height:5px;
    margin-top:.66rem;
    border-radius:999px;
    background:#ff670a;
    box-shadow:0 0 12px rgba(255,103,10,.45);
}

.pricing .price-card .btn{
    min-height:50px;
    margin-top:1rem;
    border-radius:12px;
    font-size:.9rem;
    box-shadow:
        0 10px 24px rgba(38,30,24,.1),
        0 1px 0 rgba(255,255,255,.9) inset;
}

.pricing .price-card--pop .btn{
    background:linear-gradient(90deg,#ff5e00,#ff7a18);
    box-shadow:
        0 18px 38px rgba(255,94,0,.34),
        0 1px 0 rgba(255,255,255,.42) inset;
}

@media(max-width:1024px){
    .pricing-grid{max-width:960px}
    .pricing .price-card{min-height:auto}
    .pricing .price-card--pop{min-height:auto}
}

@media(max-width:768px){
    .pricing{padding:4.5rem 0 5rem}
    .pricing .section-title{font-size:clamp(2rem,9vw,2.8rem);line-height:1.05}
    .pricing .price-card,
    .pricing .price-card--pop{min-height:auto;padding:2rem 1.25rem 1.35rem;transform:none}
    .pricing .price-card--pop:hover,
    .pricing .price-card:hover{transform:translateY(-6px)}
    .pricing .price-badge{top:1.05rem;right:-2.5rem;width:230px;font-size:.66rem}
    .pricing .price-card--pop{padding-top:4.7rem}
    .pricing .price-target{min-height:auto;margin-bottom:1.35rem}
    .pricing .price-meta{grid-template-columns:1fr}
    .pricing .price-card li{font-size:.91rem}
}

/* Site-wide liquid glass unification */
body{
    background-color:#f7f5f1;
    background-image:
        radial-gradient(ellipse at 10% 8%,rgba(255,255,255,.98),rgba(255,255,255,.34) 22%,transparent 48%),
        radial-gradient(ellipse at 90% 14%,rgba(255,238,224,.82),rgba(255,255,255,.26) 24%,transparent 48%),
        radial-gradient(ellipse at 50% 92%,rgba(255,94,0,.08),transparent 52%),
        url('[black ver.] Easy Marketing (1).png');
    background-size:auto,auto,auto,620px 620px;
    background-repeat:no-repeat,no-repeat,no-repeat,repeat;
}

.hero,.services,.work,.clients,.team,.process,.about,.testi,.pricing,.faq,.news,.cta,.footer{
    position:relative;
    isolation:isolate;
    overflow:hidden;
}

.services::before,.work::before,.clients::before,.team::before,.process::before,.about::before,.testi::before,.faq::before,.news::before,.cta::before,.footer::before{
    content:'';
    position:absolute;
    inset:-18%;
    z-index:-2;
    pointer-events:none;
    background:
        radial-gradient(ellipse at 8% 18%,rgba(255,255,255,.88),rgba(255,255,255,.16) 20%,transparent 42%),
        radial-gradient(ellipse at 92% 20%,rgba(255,245,235,.7),rgba(255,255,255,.16) 22%,transparent 44%),
        linear-gradient(116deg,transparent 0 10%,rgba(255,255,255,.52) 12%,transparent 17% 52%,rgba(255,255,255,.44) 54%,transparent 60% 100%);
    filter:blur(16px) saturate(130%);
    opacity:.72;
}

.services,.team,.process,.about,.faq,.cta,.footer{
    background:linear-gradient(135deg,rgba(249,248,245,.74),rgba(255,250,244,.58));
}

.work,.clients,.testi,.news{
    background:
        radial-gradient(ellipse at 12% 0%,rgba(255,255,255,.82),transparent 44%),
        radial-gradient(ellipse at 86% 100%,rgba(255,238,222,.58),transparent 46%),
        linear-gradient(135deg,rgba(241,241,239,.72),rgba(250,247,242,.64));
}

.hero::before{
    content:'';
    position:absolute;
    inset:-12%;
    z-index:0;
    pointer-events:none;
    background:
        radial-gradient(ellipse at 7% 16%,rgba(255,255,255,.92),rgba(255,255,255,.22) 24%,transparent 48%),
        radial-gradient(ellipse at 88% 12%,rgba(255,238,222,.72),rgba(255,255,255,.18) 24%,transparent 52%),
        linear-gradient(118deg,transparent 0 9%,rgba(255,255,255,.52) 11%,transparent 16% 50%,rgba(255,255,255,.42) 53%,transparent 59%);
    filter:blur(18px) saturate(132%);
    opacity:.7;
}

.hero-inner,.marquee,.services .container,.work .container,.stats .container,.clients .container,.team .container,.process .container,.about .container,.testi .container,.faq .container,.news .container,.cta .container,.footer .container{
    position:relative;
    z-index:1;
}

.section-label{
    color:rgba(26,26,26,.55);
    font-weight:700;
}

.section-title,.cta-title{
    color:#171717;
    text-shadow:0 2px 12px rgba(255,255,255,.54);
}

.svc-card,.work-item,.team-card,.step,.testi-card,.news-card,.client-card,.aval,.faq-item{
    border-radius:18px !important;
    background:
        radial-gradient(ellipse at 22% 10%,rgba(255,255,255,.9),rgba(255,255,255,.34) 34%,transparent 62%),
        linear-gradient(145deg,rgba(255,255,255,.58),rgba(255,255,255,.28) 48%,rgba(255,255,255,.56)) !important;
    border:1px solid rgba(255,255,255,.68) !important;
    border-right-color:rgba(0,0,0,.07) !important;
    border-bottom-color:rgba(0,0,0,.07) !important;
    backdrop-filter:blur(32px) saturate(165%) brightness(1.03) !important;
    -webkit-backdrop-filter:blur(32px) saturate(165%) brightness(1.03) !important;
    box-shadow:
        0 26px 72px rgba(37,28,20,.1),
        0 1px 0 rgba(255,255,255,.9) inset,
        0 20px 48px rgba(255,255,255,.28) inset !important;
}

.svc-card::after,.work-item::after,.team-card::after,.step::after,.testi-card::after,.news-card::after,.client-card::after,.aval::after,.faq-item::after{
    background:
        radial-gradient(420px circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(255,255,255,.86),rgba(255,94,0,.1) 30%,transparent 64%) !important;
    opacity:.38;
}

.svc-card:hover,.work-item:hover,.team-card:hover,.step:hover,.testi-card:hover,.news-card:hover,.client-card:hover,.aval:hover,.faq-item:hover{
    box-shadow:
        0 38px 92px rgba(37,28,20,.15),
        0 1px 0 rgba(255,255,255,1) inset,
        0 24px 54px rgba(255,255,255,.36) inset !important;
}

.hero-img-wrap{
    border-radius:26px;
    box-shadow:
        0 34px 90px rgba(37,28,20,.18),
        0 1px 0 rgba(255,255,255,.72) inset;
}

.hero-float-card,.btn--ghost,.btn--outline,.testi-btn{
    background:linear-gradient(145deg,rgba(255,255,255,.72),rgba(255,255,255,.34)) !important;
    border:1px solid rgba(255,255,255,.7) !important;
    border-right-color:rgba(0,0,0,.07) !important;
    border-bottom-color:rgba(0,0,0,.07) !important;
    backdrop-filter:blur(22px) saturate(160%) !important;
    -webkit-backdrop-filter:blur(22px) saturate(160%) !important;
    box-shadow:0 14px 34px rgba(37,28,20,.09),0 1px 0 rgba(255,255,255,.85) inset !important;
}

.btn--primary{
    background:linear-gradient(90deg,#ff5e00,#ff7a18);
    box-shadow:0 18px 38px rgba(255,94,0,.27),0 1px 0 rgba(255,255,255,.35) inset;
}

.footer{
    background:
        radial-gradient(ellipse at 18% 0%,rgba(255,255,255,.82),transparent 44%),
        linear-gradient(135deg,rgba(246,244,240,.86),rgba(255,247,239,.72));
}

@media(max-width:768px){
    body{background-size:auto,auto,auto,460px 460px}
    .pricing .price-badge{right:-2.6rem}
    .svc-card,.work-item,.team-card,.step,.testi-card,.news-card,.client-card,.aval,.faq-item,.pricing .price-card{
        border-radius:18px !important;
    }
}

/* v8: pearly glass, less orange, centered content */
body{
    background-color:#f7f7f5;
    background-image:
        radial-gradient(ellipse at 12% 8%,rgba(255,255,255,.98),rgba(255,255,255,.28) 24%,transparent 52%),
        radial-gradient(ellipse at 88% 10%,rgba(246,248,250,.92),rgba(255,255,255,.2) 25%,transparent 52%),
        radial-gradient(ellipse at 50% 92%,rgba(255,255,255,.72),transparent 56%),
        url('[black ver.] Easy Marketing (1).png');
    background-size:auto,auto,auto,620px 620px;
}

.section-head{
    text-align:center;
    max-width:780px;
    margin-left:auto;
    margin-right:auto;
}

.section-desc{
    margin-left:auto;
    margin-right:auto;
}

.services::before,.work::before,.clients::before,.team::before,.process::before,.about::before,.testi::before,.faq::before,.news::before,.cta::before,.footer::before{
    background:
        radial-gradient(ellipse at 10% 18%,rgba(255,255,255,.92),rgba(255,255,255,.16) 22%,transparent 46%),
        radial-gradient(ellipse at 90% 18%,rgba(245,248,250,.76),rgba(255,255,255,.14) 24%,transparent 48%),
        linear-gradient(116deg,transparent 0 10%,rgba(255,255,255,.46) 12%,transparent 17% 52%,rgba(255,255,255,.36) 54%,transparent 60% 100%);
    opacity:.68;
}

.services,.team,.process,.about,.faq,.cta,.footer,
.work,.clients,.testi,.news{
    background:
        radial-gradient(ellipse at 14% 0%,rgba(255,255,255,.78),transparent 46%),
        radial-gradient(ellipse at 88% 100%,rgba(246,248,250,.52),transparent 48%),
        linear-gradient(135deg,rgba(248,248,246,.76),rgba(255,255,255,.58)) !important;
}

.hero::before{
    background:
        radial-gradient(ellipse at 8% 16%,rgba(255,255,255,.9),rgba(255,255,255,.2) 24%,transparent 50%),
        radial-gradient(ellipse at 88% 12%,rgba(246,248,250,.76),rgba(255,255,255,.16) 24%,transparent 52%),
        linear-gradient(118deg,transparent 0 9%,rgba(255,255,255,.45) 11%,transparent 16% 50%,rgba(255,255,255,.35) 53%,transparent 59%);
}

.pricing{
    background:
        radial-gradient(ellipse at 14% 14%,rgba(255,255,255,.98),rgba(255,255,255,.34) 26%,transparent 52%),
        radial-gradient(ellipse at 86% 12%,rgba(246,248,250,.88),rgba(255,255,255,.22) 26%,transparent 52%),
        radial-gradient(ellipse at 50% 110%,rgba(255,255,255,.72),transparent 58%),
        linear-gradient(135deg,#f9f9f7 0%,#f1f2f1 48%,#fbfbf8 100%) !important;
}

.pricing::after{
    background:
        linear-gradient(116deg,transparent 0 7%,rgba(255,255,255,.68) 9%,transparent 12% 46%,rgba(255,255,255,.56) 48%,transparent 51% 100%),
        linear-gradient(22deg,transparent 0 19%,rgba(255,255,255,.5) 22%,transparent 29% 100%),
        radial-gradient(ellipse at 0 100%,rgba(255,255,255,.84),transparent 44%),
        radial-gradient(ellipse at 100% 100%,rgba(255,255,255,.78),transparent 42%) !important;
    opacity:.78;
}

.svc-card,.team-card,.step,.testi-card,.news-card,.client-card,.aval,.faq-item,.pricing .price-card{
    background:
        radial-gradient(ellipse at 22% 10%,rgba(255,255,255,.95),rgba(255,255,255,.42) 34%,transparent 62%),
        radial-gradient(ellipse at 82% 92%,rgba(255,255,255,.72),rgba(255,255,255,.22) 28%,transparent 56%),
        linear-gradient(145deg,rgba(255,255,255,.6),rgba(255,255,255,.3) 50%,rgba(255,255,255,.58)) !important;
    border-color:rgba(255,255,255,.78) !important;
    box-shadow:
        0 28px 78px rgba(18,22,25,.1),
        0 1px 0 rgba(255,255,255,.92) inset,
        0 24px 58px rgba(255,255,255,.34) inset !important;
}

.svc-card::after,.team-card::after,.step::after,.testi-card::after,.news-card::after,.client-card::after,.aval::after,.faq-item::after,.pricing .price-card::after{
    background:
        radial-gradient(420px circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(255,255,255,.95),rgba(210,220,230,.24) 34%,transparent 68%) !important;
}

.svc-card h3,.svc-card p,.team-card h3,.team-card p,.step h3,.step p,.client-card,.news-body h3,.news-body p,.price-card h3,.price-target,.price-val{
    text-align:center;
}

.svc-icon,.svc-tags,.team-ava{
    margin-left:auto;
    margin-right:auto;
}

.svc-tags{
    justify-content:center;
}

.step-top{
    justify-content:center;
}

.step-line{
    display:none;
}

.pricing .price-card{
    box-shadow:
        0 34px 96px rgba(18,22,25,.11),
        0 1px 0 rgba(255,255,255,.94) inset,
        0 28px 66px rgba(255,255,255,.36) inset !important;
}

.pricing .price-card--pop{
    border-color:rgba(255,120,45,.42) !important;
    box-shadow:
        0 0 0 1px rgba(255,120,45,.18),
        0 36px 105px rgba(18,22,25,.12),
        0 0 34px rgba(255,94,0,.08),
        0 1px 0 rgba(255,255,255,.94) inset !important;
}

.pricing .price-card--pop:hover{
    box-shadow:
        0 0 0 1px rgba(255,120,45,.24),
        0 46px 118px rgba(18,22,25,.16),
        0 0 42px rgba(255,94,0,.1),
        0 1px 0 rgba(255,255,255,1) inset !important;
}

.pricing .price-badge{
    background:linear-gradient(90deg,#ff6a12,#ff8b3d);
    box-shadow:0 16px 32px rgba(255,94,0,.22);
}

.pricing .price-val{
    background:linear-gradient(135deg,#7a3108,#b84a0b 70%,#e76014);
    -webkit-background-clip:text;
    background-clip:text;
}

.pricing .price-card li::before{
    background:#ff6a12;
    box-shadow:none;
}

.pricing .price-card--pop .btn,.btn--primary{
    background:linear-gradient(90deg,#ff6410,#ff7d24);
    box-shadow:0 16px 34px rgba(255,94,0,.22),0 1px 0 rgba(255,255,255,.38) inset;
}

@media(max-width:768px){
    .section-head{text-align:center}
    .section-title{text-align:center}
    .section-desc{text-align:center}
}

/* v9: visible glass refraction without orange wash */
.pricing,.services,.work,.clients,.team,.process,.about,.testi,.faq,.news,.cta,.footer{
    background-image:
        radial-gradient(ellipse at 9% 12%,rgba(255,255,255,.96),rgba(255,255,255,.24) 24%,transparent 52%),
        radial-gradient(ellipse at 91% 10%,rgba(248,250,252,.86),rgba(255,255,255,.2) 25%,transparent 52%),
        linear-gradient(123deg,transparent 0 8%,rgba(255,255,255,.48) 10%,transparent 14% 48%,rgba(226,232,238,.22) 51%,transparent 56%),
        linear-gradient(27deg,transparent 0 20%,rgba(255,255,255,.46) 23%,transparent 29% 100%),
        linear-gradient(135deg,#fafaf8,#f1f2f1 48%,#fbfbf9) !important;
}

.pricing::before,.services::after,.work::after,.clients::after,.team::after,.process::after,.about::after,.testi::after,.faq::after,.news::after,.cta::after{
    content:'';
    position:absolute;
    inset:-16%;
    z-index:-1;
    pointer-events:none;
    background:
        radial-gradient(ellipse at 0 28%,rgba(255,255,255,.8),rgba(255,255,255,.16) 18%,transparent 38%),
        radial-gradient(ellipse at 100% 22%,rgba(255,255,255,.72),rgba(238,242,246,.16) 20%,transparent 42%),
        conic-gradient(from 138deg at 18% 42%,transparent 0 18deg,rgba(255,255,255,.42) 26deg,transparent 40deg 360deg),
        conic-gradient(from -22deg at 88% 28%,transparent 0 22deg,rgba(210,218,226,.2) 31deg,transparent 48deg 360deg);
    filter:blur(18px) saturate(128%);
    opacity:.62;
}

.svc-card,.team-card,.step,.testi-card,.news-card,.client-card,.aval,.faq-item,.pricing .price-card{
    background:
        linear-gradient(145deg,rgba(255,255,255,.5),rgba(255,255,255,.2) 46%,rgba(255,255,255,.46)) !important;
    border:1px solid rgba(255,255,255,.64) !important;
    border-top-color:rgba(255,255,255,.96) !important;
    border-left-color:rgba(255,255,255,.9) !important;
    border-right-color:rgba(178,188,198,.22) !important;
    border-bottom-color:rgba(150,160,170,.2) !important;
    box-shadow:
        0 30px 80px rgba(18,22,25,.12),
        0 1px 0 rgba(255,255,255,.95) inset,
        18px 18px 50px rgba(255,255,255,.22) inset,
        -18px -18px 46px rgba(210,218,226,.16) inset !important;
}

.svc-card::before,.team-card::before,.step::before,.testi-card::before,.news-card::before,.client-card::before,.aval::before,.faq-item::before,.pricing .price-card::before{
    content:'';
    position:absolute;
    inset:0;
    z-index:1;
    border-radius:inherit;
    background:
        linear-gradient(126deg,rgba(255,255,255,.72),transparent 30%),
        linear-gradient(306deg,rgba(255,255,255,.34),transparent 42%),
        radial-gradient(circle at 86% 12%,rgba(255,255,255,.62),transparent 24%);
    opacity:.76;
    pointer-events:none;
}

.pricing .price-card{
    background:
        radial-gradient(ellipse at 24% 8%,rgba(255,255,255,.7),transparent 42%),
        linear-gradient(145deg,rgba(255,255,255,.48),rgba(255,255,255,.18) 48%,rgba(255,255,255,.46)) !important;
}

.pricing .price-card--pop{
    border-color:rgba(255,130,55,.34) !important;
    box-shadow:
        0 0 0 1px rgba(255,130,55,.13),
        0 36px 105px rgba(18,22,25,.12),
        0 0 28px rgba(255,94,0,.055),
        0 1px 0 rgba(255,255,255,.94) inset,
        -18px -18px 46px rgba(210,218,226,.12) inset !important;
}

.pricing .price-badge{
    background:linear-gradient(90deg,#ff6a12,#ff8332);
}

.pricing .price-meta span,.btn--ghost,.btn--outline,.testi-btn,.hero-float-card{
    background:linear-gradient(180deg,rgba(255,255,255,.62),rgba(255,255,255,.32)) !important;
    border-color:rgba(255,255,255,.7) !important;
}

/* v10: stronger glass edges, neutral pearl refraction */
.pricing{
    background:
        radial-gradient(ellipse at 4% 18%,rgba(255,255,255,.95),rgba(222,228,234,.24) 22%,transparent 46%),
        radial-gradient(ellipse at 96% 18%,rgba(255,255,255,.92),rgba(222,228,234,.2) 22%,transparent 46%),
        radial-gradient(ellipse at 50% 98%,rgba(226,232,238,.34),transparent 58%),
        linear-gradient(126deg,rgba(255,255,255,.2) 0 9%,rgba(210,218,226,.16) 12%,transparent 16% 42%,rgba(255,255,255,.42) 45%,transparent 51%),
        linear-gradient(24deg,transparent 0 18%,rgba(210,218,226,.18) 22%,rgba(255,255,255,.5) 25%,transparent 31%),
        #f7f8f7 !important;
}

.pricing-grid{
    position:relative;
}

.pricing-grid::before{
    content:'';
    position:absolute;
    inset:-4rem -3rem;
    z-index:0;
    pointer-events:none;
    background:
        radial-gradient(ellipse at 0 35%,rgba(205,214,224,.22),transparent 42%),
        radial-gradient(ellipse at 100% 35%,rgba(205,214,224,.2),transparent 42%),
        linear-gradient(115deg,transparent 0 8%,rgba(255,255,255,.55) 10%,transparent 15% 50%,rgba(210,218,226,.18) 53%,transparent 60%);
    filter:blur(20px);
    opacity:.9;
}

.pricing .price-card{
    background:
        radial-gradient(ellipse at 18% 8%,rgba(255,255,255,.76),transparent 40%),
        radial-gradient(ellipse at 78% 96%,rgba(230,235,240,.2),transparent 48%),
        linear-gradient(145deg,rgba(255,255,255,.38),rgba(255,255,255,.16) 50%,rgba(255,255,255,.34)) !important;
    border-top-color:rgba(255,255,255,1) !important;
    border-left-color:rgba(255,255,255,.94) !important;
    border-right-color:rgba(160,170,180,.28) !important;
    border-bottom-color:rgba(145,155,165,.28) !important;
    box-shadow:
        0 34px 96px rgba(18,22,25,.13),
        0 1px 0 rgba(255,255,255,1) inset,
        22px 22px 60px rgba(255,255,255,.3) inset,
        -20px -20px 56px rgba(190,200,210,.16) inset !important;
}

.pricing .price-card::before{
    opacity:.9;
    background:
        linear-gradient(128deg,rgba(255,255,255,.86),rgba(255,255,255,.16) 20%,transparent 34%),
        linear-gradient(308deg,rgba(255,255,255,.48),transparent 44%),
        radial-gradient(circle at 86% 10%,rgba(255,255,255,.78),transparent 24%),
        radial-gradient(circle at 10% 94%,rgba(220,228,236,.18),transparent 30%);
}

.pricing .price-card::after{
    background:
        radial-gradient(390px circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(255,255,255,.92),rgba(218,226,234,.24) 38%,transparent 70%),
        linear-gradient(140deg,rgba(255,255,255,.28),transparent 28% 70%,rgba(210,218,226,.12)) !important;
}


/* ═══════════════════════════════════════
   v11 — UI/UX PREMIUM UPGRADE
   Sửa alignment, card differentiation,
   process stepper, CTA, header, testi,
   section rhythm. Không touch pricing.
   ═══════════════════════════════════════ */

/* ─── SECTION RHYTHM — Phân biệt background ─── */
/* Trả lại warm white cho odd sections */
.services, .process, .about, .faq {
    background:
        radial-gradient(ellipse at 8% 0%, rgba(255,255,255,.92), transparent 44%),
        radial-gradient(ellipse at 92% 100%, rgba(255,248,240,.64), transparent 48%),
        linear-gradient(135deg, #f9f8f5 0%, #faf9f6 100%) !important;
}

/* Soft cool-grey cho even sections */
.work, .clients, .news {
    background:
        radial-gradient(ellipse at 10% 0%, rgba(255,255,255,.88), transparent 44%),
        radial-gradient(ellipse at 88% 100%, rgba(240,243,248,.52), transparent 48%),
        linear-gradient(135deg, #f3f4f3 0%, #f0f1f0 100%) !important;
}

/* Team section — warm peach tint */
.team {
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255,248,240,.9), transparent 52%),
        radial-gradient(ellipse at 92% 88%, rgba(255,238,220,.5), transparent 48%),
        linear-gradient(135deg, #fdf9f5 0%, #f8f5ef 100%) !important;
}

/* Testi — very light cool */
.testi {
    background:
        radial-gradient(ellipse at 12% 10%, rgba(255,255,255,.96), transparent 44%),
        linear-gradient(135deg, #f8f9fb 0%, #f4f5f7 100%) !important;
}

/* Stats band — pure white with subtle shadow feel */
.stats {
    background: rgba(255,255,255,.92) !important;
    box-shadow: 0 0 0 1px rgba(0,0,0,.04);
}

/* ─── HEADER v11 — Height + CTA accent ─── */
.header {
    padding: 0;
}
.nav {
    height: clamp(68px, 6vw, 84px);
    display: flex;
    align-items: center;
}
/* CTA button trong nav — visible accent ngay từ đầu */
.nav-cta {
    background: var(--accent) !important;
    color: #fff !important;
    border-color: var(--accent) !important;
    font-weight: 700;
    padding: .6rem 1.4rem;
    font-size: .82rem;
    letter-spacing: .3px;
    box-shadow: 0 6px 20px rgba(255,94,0,.25);
    transition: all .3s var(--ease);
}
.nav-cta:hover {
    background: #e55500 !important;
    transform: translateY(-1px);
    box-shadow: 0 10px 28px rgba(255,94,0,.32);
}
/* Header scrolled — rõ hơn */
.header.scrolled {
    background: rgba(255,255,255,.92) !important;
    backdrop-filter: blur(20px) saturate(1.5);
    box-shadow: 0 1px 0 rgba(0,0,0,.06), 0 4px 24px rgba(0,0,0,.04);
    border-bottom: none;
}

/* ─── FEATURE CARDS (svc-card) — Trả lại left-align + icon chip ─── */
.svc-card {
    text-align: left !important;
}
.svc-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(255,94,0,.12), rgba(255,94,0,.06));
    display: flex !important;
    align-items: center;
    justify-content: center;
    margin: 0 0 1.4rem 0 !important;
    flex-shrink: 0;
    border: 1px solid rgba(255,94,0,.15);
    transition: all .3s;
}
.svc-card:hover .svc-icon {
    background: linear-gradient(135deg, rgba(255,94,0,.2), rgba(255,94,0,.1));
    transform: scale(1.06);
}
.svc-card h3, .svc-card p {
    text-align: left !important;
}
.svc-tags {
    justify-content: flex-start !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}
.svc-num {
    font-size: 5rem;
    font-weight: 900;
    color: rgba(0,0,0,.025);
    line-height: 1;
    position: absolute;
    top: .2rem;
    right: 1rem;
    pointer-events: none;
    user-select: none;
}

/* ─── PROCESS SECTION v11 — Stepper Timeline ─── */
/* Desktop: horizontal stepper với connector */
.process-grid {
    position: relative;
    align-items: start;
}

/* Connector line ngang giữa các step */
.process-grid::before {
    content: '';
    position: absolute;
    top: 36px; /* Căn giữa badge */
    left: calc(24px + 2.5%);
    right: calc(24px + 2.5%);
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,94,0,.3) 15%, rgba(255,94,0,.3) 85%, transparent);
    z-index: 0;
    pointer-events: none;
}

.step {
    text-align: left !important;
    position: relative;
    z-index: 1;
}

/* Step number badge — circle lớn thay thế */
.step-top {
    justify-content: flex-start !important;
    margin-bottom: 1.4rem;
    display: flex;
    align-items: center;
    gap: .9rem;
}

.step-num {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent), #ff8a3d);
    color: #fff !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    font-weight: 800;
    letter-spacing: 1px;
    flex-shrink: 0;
    box-shadow: 0 6px 20px rgba(255,94,0,.3);
    border: 2px solid rgba(255,255,255,.8);
    /* Hiển thị dưới dạng flex container */
    display: flex !important;
    line-height: 1;
}

/* Ẩn step-line cũ — thay bằng ::before trên grid */
.step-line { display: none; }

.step h3 { text-align: left !important; }
.step p { text-align: left !important; }

/* Step hover — subtle accent border */
.step:hover {
    border-color: rgba(255,94,0,.25) !important;
}

/* Mobile: vertical stepper */
@media(max-width: 768px) {
    .process-grid::before {
        display: none;
    }
    .process-grid {
        gap: 1rem;
    }
}

/* ─── TEAM CARDS v11 — Top accent + avatar upgrade ─── */
.team-card {
    position: relative;
    padding-top: 2.4rem !important;
    text-align: left !important;
}

/* Accent line trên đầu card */
.team-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 1.5rem;
    right: 1.5rem;
    height: 3px;
    border-radius: 0 0 3px 3px;
    background: linear-gradient(90deg, var(--accent), rgba(255,94,0,.4), transparent);
    opacity: 0;
    transition: opacity .4s var(--ease);
    z-index: 2;
}
.team-card:hover::before {
    opacity: 1;
}

/* Avatar — canh trái thay vì center */
.team-ava {
    margin: 0 0 1.2rem 0 !important;
    width: 56px;
    height: 56px;
    font-size: 1rem;
    box-shadow: 0 8px 24px rgba(255,94,0,.2);
}

.team-card h3, .team-bio {
    text-align: left !important;
}
.team-role {
    text-align: left !important;
    margin-bottom: 1rem;
}

/* ─── TESTIMONIAL CARDS v11 — Quote mark + size ─── */
.testi-card {
    position: relative;
    padding-top: 3rem !important;
}

/* Quote mark lớn mờ */
.testi-card::before {
    content: '\201C';
    position: absolute !important;
    top: .8rem !important;
    left: 1.5rem !important;
    right: auto !important;
    font-size: 5rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    color: var(--accent) !important;
    opacity: .12 !important;
    font-family: Georgia, serif !important;
    z-index: 2 !important;
    background: none !important;
    border-radius: 0 !important;
    pointer-events: none;
}

.testi-card p {
    font-size: 1rem !important;
    line-height: 1.75 !important;
}

/* Avatar + footer upgrade */
.testi-ava {
    width: 52px;
    height: 52px;
    font-size: .82rem;
    box-shadow: 0 6px 18px rgba(255,94,0,.18);
}

/* Testi-card--feat: rõ accent hơn */
.testi-card--feat {
    border-color: rgba(255,94,0,.22) !important;
    box-shadow:
        0 0 0 1px rgba(255,94,0,.1),
        0 30px 80px rgba(18,22,25,.12),
        0 1px 0 rgba(255,255,255,.95) inset !important;
}

/* Stars */
.testi-stars {
    font-size: 1.1rem;
    letter-spacing: 3px;
    margin-bottom: 1.4rem;
}

/* ─── ABOUT SECTION v11 — 2-col tighter ─── */
.about-layout {
    gap: clamp(3rem, 7vw, 6rem);
    align-items: center;
}

/* Accent vertical bar bên trái title */
.about-left .section-title {
    padding-left: 1.2rem;
    border-left: 3px solid var(--accent);
    margin-bottom: 1.5rem;
}

.about-vals .aval {
    text-align: left !important;
}
.aval h4 {
    text-align: left !important;
    font-size: 1rem;
    margin-bottom: .5rem;
}
.aval p {
    text-align: left !important;
}

/* ─── FINAL CTA v11 — Card treatment ─── */
.cta {
    padding: clamp(4rem, 8vw, 7rem) 0;
    background:
        radial-gradient(ellipse at 50% 60%, rgba(255,94,0,.07), transparent 60%),
        linear-gradient(135deg, #f9f7f4 0%, #faf8f4 100%) !important;
}

/* Xóa ::before blob cũ — sẽ dùng card wrap */
.cta::before { display: none; }

/* CTA card container */
.cta-inner {
    background:
        radial-gradient(ellipse at 20% 10%, rgba(255,255,255,.9), transparent 50%),
        radial-gradient(ellipse at 80% 90%, rgba(255,238,220,.6), transparent 50%),
        linear-gradient(135deg, rgba(255,255,255,.85), rgba(255,248,240,.7));
    border: 1px solid rgba(255,94,0,.18);
    border-radius: 32px;
    padding: clamp(3rem, 6vw, 5rem) clamp(2rem, 5vw, 4rem);
    position: relative;
    overflow: hidden;
    box-shadow:
        0 0 0 1px rgba(255,255,255,.9) inset,
        0 40px 100px rgba(255,94,0,.08),
        0 20px 60px rgba(0,0,0,.06);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

/* Glow phía sau card */
.cta-inner::before {
    content: '';
    position: absolute;
    inset: -20%;
    z-index: -1;
    background: radial-gradient(ellipse at 50% 50%, rgba(255,94,0,.08), transparent 60%);
    pointer-events: none;
    filter: blur(40px);
}

/* Floating decorative dots */
.cta-inner::after {
    content: '';
    position: absolute;
    top: 2rem;
    right: 2rem;
    width: 120px;
    height: 120px;
    background-image:
        radial-gradient(circle, rgba(255,94,0,.15) 1px, transparent 1px);
    background-size: 16px 16px;
    border-radius: 50%;
    opacity: .5;
    pointer-events: none;
}

.cta-title {
    font-size: clamp(2.8rem, 6vw, 5.2rem) !important;
    margin-bottom: 1.2rem;
    line-height: 1.05;
}

.cta-desc {
    font-size: 1.08rem;
    max-width: 520px;
    margin-bottom: 2.8rem;
    color: var(--text-2);
}

/* CTA buttons */
.cta-actions .btn--primary {
    padding: 1.1rem 2.6rem;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: .2px;
    box-shadow: 0 20px 50px rgba(255,94,0,.3), 0 1px 0 rgba(255,255,255,.35) inset;
}

.cta-actions .btn--ghost {
    padding: 1.1rem 2.4rem;
    font-size: 1rem;
    font-weight: 600;
    border-color: rgba(0,0,0,.12) !important;
    color: var(--text) !important;
}

/* ─── STATS BAND v11 — Dividers + larger numbers ─── */
.stats {
    padding: clamp(3rem, 5vw, 4.5rem) 0;
}
.stat {
    position: relative;
}
/* Divider dọc giữa các stat */
.stat:not(:last-child)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 20%;
    height: 60%;
    width: 1px;
    background: linear-gradient(180deg, transparent, rgba(0,0,0,.1) 30%, rgba(0,0,0,.1) 70%, transparent);
}
.stat-num {
    font-size: clamp(3rem, 5.5vw, 4rem);
    color: #1a1a1a;
}
.stat-suffix {
    font-size: clamp(1.8rem, 3vw, 2.4rem);
    vertical-align: super;
    line-height: 1;
}
.stat p {
    font-size: .82rem;
    letter-spacing: 1px;
    margin-top: .6rem;
}

/* ─── KNOWLEDGE CARDS (news) v11 — Content preview ─── */
/* News/Blog section */
.news {
    padding: clamp(4.5rem, 8vw, 8rem) 0;
}

/* Thumbnail area rõ hơn */
.news-thumb {
    height: 220px;
    overflow: hidden;
    border-radius: 12px 12px 0 0;
    position: relative;
}

/* Category tag nổi hơn */
.news-tag {
    background: linear-gradient(135deg, var(--accent), #ff7a18) !important;
    color: #fff !important;
    padding: .35rem .9rem !important;
    border-radius: 100px !important;
    font-size: .68rem !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    box-shadow: 0 4px 12px rgba(255,94,0,.2);
}

.news-body {
    padding: 1.6rem !important;
}

.news-body h3 {
    font-size: 1.08rem !important;
    font-weight: 700 !important;
    line-height: 1.45 !important;
    margin-bottom: .6rem !important;
    text-align: left !important;
    color: var(--text) !important;
}

.news-body p {
    font-size: .88rem !important;
    line-height: 1.65 !important;
    text-align: left !important;
    color: var(--text-2) !important;
    margin-top: .5rem !important;
}

.news-date {
    font-size: .72rem;
    color: var(--text-3);
    margin-top: .9rem;
}

/* ─── CLIENTS WALL v11 — Trust strip ─── */
.clients {
    padding: clamp(3.5rem, 6vw, 5.5rem) 0;
    border-top: 1px solid rgba(0,0,0,.06);
    border-bottom: 1px solid rgba(0,0,0,.06);
}

.client-card {
    padding: 1.4rem 1.2rem !important;
    transition: all .35s var(--ease);
    opacity: .75;
}
.client-card:hover {
    opacity: 1;
    transform: translateY(-2px) !important;
}
.client-name {
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: .2px;
}

/* ─── FOOTER v11 — Brand col wider ─── */
.footer {
    padding: 5rem 0 2.5rem;
    background:
        linear-gradient(135deg, rgba(248,247,244,.98), rgba(244,243,240,1)) !important;
    border-top: 1px solid rgba(0,0,0,.07) !important;
}

.footer-top {
    margin-bottom: 3.5rem;
    padding-bottom: 3rem;
    border-bottom: 1px solid rgba(0,0,0,.07);
    display: flex;
    align-items: center;
    gap: 2rem;
}

.footer-brand-logo {
    height: clamp(48px, 6vw, 80px);
    filter: brightness(0);
}

.footer-tagline {
    font-size: .95rem;
    line-height: 1.75;
    color: var(--text-2);
    max-width: 360px;
}

.footer-col h4 {
    font-size: .72rem;
    letter-spacing: 2px;
    margin-bottom: 1rem !important;
    color: var(--text-3);
    font-weight: 600;
}

.footer-col a, .footer-col p {
    font-size: .88rem;
    color: var(--text-2);
    line-height: 1.7;
    transition: color .25s;
}
.footer-col a:hover { color: var(--accent); }

.footer-bottom {
    font-size: .78rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(0,0,0,.07);
    color: var(--text-3);
}

/* ─── WORK / PORTFOLIO v11 — Metric upgrade ─── */
.work-metric strong {
    font-size: 1.5rem !important;
    font-weight: 900 !important;
    color: var(--accent) !important;
    letter-spacing: -.5px;
}
.work-metric span {
    font-size: .72rem;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--text-3);
    margin-top: .15rem;
}

.work-info {
    padding: 1.6rem 2rem 2rem !important;
}

.work-info h3 {
    font-size: 1.25rem !important;
    font-weight: 800 !important;
    margin-bottom: .6rem !important;
}

.work-info > p {
    font-size: .9rem !important;
    line-height: 1.7 !important;
    margin-bottom: 1.5rem !important;
}

/* ─── SECTION HEAD — Trả lại left-align cho non-center sections ─── */
/* Override v8's global center-align cho section-head */
.section-head:not(.center) {
    text-align: left !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}
.section-head:not(.center) .section-desc {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* ─── MARQUEE — Trust strip wrapper ─── */
.marquee {
    background: rgba(255,255,255,.6);
    backdrop-filter: blur(12px);
}

/* ─── GLOBAL TYPOGRAPHY v11 ─── */
/* h1 hero lớn hơn */
.hero-title {
    font-size: 50px !important;
    line-height: 1.09 !important;
    letter-spacing: -.5px;
}

/* Section title rõ hơn */
.section-title {
    font-size: clamp(2rem, 3.8vw, 3.4rem) !important;
    letter-spacing: -.3px;
    line-height: 1.1;
}

/* Hero sub-heading */
.hero-sub {
    font-size: clamp(1rem, 1.2vw, 1.1rem) !important;
    line-height: 1.8 !important;
}

/* ─── HERO TRUST BADGES — Nổi hơn ─── */
.hero-trust {
    margin-top: 2.8rem;
    padding-top: 2rem;
    border-top: 1px solid rgba(0,0,0,.08);
}
.trust-item strong {
    font-size: 1.5rem !important;
    font-weight: 900 !important;
}
.trust-item span {
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 1.2px;
}

/* ─── SCROLL REVEAL — keep ─── */

/* ─── RESPONSIVE v11 — Mobile fixes ─── */
@media(max-width: 1024px) {
    .nav { height: 72px; }
    .process-grid::before { display: none; }
    .process-grid { grid-template-columns: repeat(2, 1fr); }
    .about-left .section-title { border-left: none; padding-left: 0; }
}

@media(max-width: 768px) {
    .nav { height: 64px; }
    .nav-cta { display: none; } /* Hide nav CTA on mobile — hamburger takes over */
    .cta-inner { border-radius: 24px; padding: 2.5rem 1.5rem; }
    .cta-inner::after { display: none; }
    .cta-title { font-size: clamp(2.2rem, 9vw, 3rem) !important; }
    .team-card { text-align: center !important; }
    .team-ava { margin: 0 auto 1.2rem !important; }
    .team-card h3, .team-bio, .team-role { text-align: center !important; }
    .step { text-align: center !important; }
    .step-top { justify-content: center !important; }
    .step h3, .step p { text-align: center !important; }
    .svc-card { text-align: left !important; }
    .stat:not(:last-child)::after { display: none; }
    .stats-row { grid-template-columns: repeat(2, 1fr); gap: 0; }
    .stat { padding: 1.5rem 1rem; }
}

.news-date {
    font-size: .72rem;
    color: var(--text-3);
    margin-top: .9rem;
}

/* ─── CLIENTS WALL v11 — Trust strip ─── */
.clients {
    padding: clamp(3.5rem, 6vw, 5.5rem) 0;
    border-top: 1px solid rgba(0,0,0,.06);
    border-bottom: 1px solid rgba(0,0,0,.06);
}

.client-card {
    padding: 1.4rem 1.2rem !important;
    transition: all .35s var(--ease);
    opacity: .75;
}
.client-card:hover {
    opacity: 1;
    transform: translateY(-2px) !important;
}
.client-name {
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: .2px;
}

/* ─── FOOTER v11 — Brand col wider ─── */
.footer {
    padding: 5rem 0 2.5rem;
    background:
        linear-gradient(135deg, rgba(248,247,244,.98), rgba(244,243,240,1)) !important;
    border-top: 1px solid rgba(0,0,0,.07) !important;
}

.footer-top {
    margin-bottom: 3.5rem;
    padding-bottom: 3rem;
    border-bottom: 1px solid rgba(0,0,0,.07);
    display: flex;
    align-items: center;
    gap: 2rem;
}

.footer-brand-logo {
    height: clamp(48px, 6vw, 80px);
    filter: brightness(0);
}

.footer-tagline {
    font-size: .95rem;
    line-height: 1.75;
    color: var(--text-2);
    max-width: 360px;
}

.footer-col h4 {
    font-size: .72rem;
    letter-spacing: 2px;
    margin-bottom: 1rem !important;
    color: var(--text-3);
    font-weight: 600;
}

.footer-col a, .footer-col p {
    font-size: .88rem;
    color: var(--text-2);
    line-height: 1.7;
    transition: color .25s;
}
.footer-col a:hover { color: var(--accent); }

.footer-bottom {
    font-size: .78rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(0,0,0,.07);
    color: var(--text-3);
}

/* ─── WORK / PORTFOLIO v11 — Metric upgrade ─── */
.work-metric strong {
    font-size: 1.5rem !important;
    font-weight: 900 !important;
    color: var(--accent) !important;
    letter-spacing: -.5px;
}
.work-metric span {
    font-size: .72rem;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--text-3);
    margin-top: .15rem;
}

.work-info {
    padding: 1.6rem 2rem 2rem !important;
}

.work-info h3 {
    font-size: 1.25rem !important;
    font-weight: 800 !important;
    margin-bottom: .6rem !important;
}

.work-info > p {
    font-size: .9rem !important;
    line-height: 1.7 !important;
    margin-bottom: 1.5rem !important;
}

/* ─── SECTION HEAD — Trả lại left-align cho non-center sections ─── */
/* Override v8's global center-align cho section-head */
.section-head:not(.center) {
    text-align: left !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}
.section-head:not(.center) .section-desc {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* ─── MARQUEE — Trust strip wrapper ─── */
.marquee {
    background: rgba(255,255,255,.6);
    backdrop-filter: blur(12px);
}

/* ─── GLOBAL TYPOGRAPHY v11 ─── */
/* h1 hero lớn hơn */
.hero-title {
    font-size: 50px !important;
    line-height: 1.09 !important;
    letter-spacing: -.5px;
}

/* Section title rõ hơn */
.section-title {
    font-size: clamp(2rem, 3.8vw, 3.4rem) !important;
    letter-spacing: -.3px;
    line-height: 1.1;
}

/* Hero sub-heading */
.hero-sub {
    font-size: clamp(1rem, 1.2vw, 1.1rem) !important;
    line-height: 1.8 !important;
}

/* ─── HERO TRUST BADGES — Nổi hơn ─── */
.hero-trust {
    margin-top: 2.8rem;
    padding-top: 2rem;
    border-top: 1px solid rgba(0,0,0,.08);
}
.trust-item strong {
    font-size: 1.5rem !important;
    font-weight: 900 !important;
}
.trust-item span {
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 1.2px;
}

/* ─── SCROLL REVEAL — keep ─── */

/* ─── RESPONSIVE v11 — Mobile fixes ─── */
@media(max-width: 1024px) {
    .nav { height: 72px; }
    .process-grid::before { display: none; }
    .process-grid { grid-template-columns: repeat(2, 1fr); }
    .about-left .section-title { border-left: none; padding-left: 0; }
}

@media(max-width: 768px) {
    .nav { height: 64px; }
    .nav-cta { display: none; } /* Hide nav CTA on mobile — hamburger takes over */
    .cta-inner { border-radius: 24px; padding: 2.5rem 1.5rem; }
    .cta-inner::after { display: none; }
    .cta-title { font-size: clamp(2.2rem, 9vw, 3rem) !important; }
    .team-card { text-align: center !important; }
    .team-ava { margin: 0 auto 1.2rem !important; }
    .team-card h3, .team-bio, .team-role { text-align: center !important; }
    .step { text-align: center !important; }
    .step-top { justify-content: center !important; }
    .step h3, .step p { text-align: center !important; }
    .svc-card { text-align: left !important; }
    .stat:not(:last-child)::after { display: none; }
    .stats-row { grid-template-columns: repeat(2, 1fr); gap: 0; }
    .stat { padding: 1.5rem 1rem; }
    .section-head:not(.center) { text-align: center !important; }
    .section-head:not(.center) .section-desc { margin: 0 auto !important; }
    .about-left .section-title { text-align: center; padding-left: 0; border-left: none; }
    .aval { text-align: center !important; }
    .aval h4, .aval p { text-align: center !important; }
    .footer-top { flex-direction: column; align-items: flex-start; gap: 1.2rem; padding-bottom: 2rem; margin-bottom: 2.5rem; }
}

/* ═══════════════════════════════════════
   v12 — BACKGROUND TEXTURE + HERO ILLUS
   ═══════════════════════════════════════ */

/* ─── GLOBAL: background.png texture overlay cho mọi section ─── */
body {
    background-color: #f8f6f2;
    background-image:
        url('background.png');
    background-size: 1080px 1080px;
    background-repeat: repeat;
    background-attachment: fixed;
}

/* Tất cả section dùng texture paper — override tất cả v8-v11 backgrounds */
.hero, .marquee,
.services, .work, .clients, .stats, .team,
.process, .about, .testi, .pricing, .faq, .news, .cta, .footer {
    background-color: transparent !important;
    background-image: none !important;
}

/* Section layer: mỗi section vẫn có tint nhẹ để tạo rhythm */
.services, .process, .about, .faq {
    background-color: rgba(252, 250, 247, 0.82) !important;
}
.work, .clients, .news {
    background-color: rgba(244, 244, 242, 0.85) !important;
}
.team {
    background-color: rgba(254, 250, 244, 0.8) !important;
}
.testi {
    background-color: rgba(248, 250, 252, 0.82) !important;
}
.stats {
    background-color: rgba(255, 255, 255, 0.75) !important;
    box-shadow: 0 0 0 1px rgba(0,0,0,.04);
}
.pricing {
    background-color: rgba(249, 250, 248, 0.88) !important;
}
.cta {
    background-color: rgba(254, 248, 240, 0.88) !important;
}
.footer {
    background-color: rgba(244, 242, 238, 0.95) !important;
    border-top: 1px solid rgba(0,0,0,.07);
}
.hero {
    background-color: rgba(252, 250, 246, 0.75) !important;
}

/* Xóa ::before blobs (không cần nữa vì đã có texture) */
.services::before, .work::before, .clients::before, .team::before,
.process::before, .about::before, .testi::before, .faq::before,
.news::before, .cta::before, .footer::before {
    display: none !important;
}
/* Xóa cả ::after blobs */
.services::after, .work::after, .clients::after, .team::after,
.process::after, .about::after, .testi::after, .faq::after,
.news::after, .cta::after {
    display: none !important;
}

/* ─── HERO ILLUSTRATION LAYOUT ─── */
/* hero-inner grid already defined at line ~128 */
/* Just ensure illustration column aligns center */

.hero-visual {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-illustration {
    position: relative;
    width: 100%;
    max-width: 560px;
}

/* Main illustration */
.hero-illus-main {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
    /* Nhẹ drop shadow để nổi trên texture */
    filter: drop-shadow(0 24px 60px rgba(0,0,0,.12));
    animation: heroFloat 5s ease-in-out infinite;
}

/* Floating clouds */
.hero-illus-cloud {
    position: absolute;
    width: clamp(80px, 12vw, 140px);
    animation: cloudDrift 7s ease-in-out infinite;
    opacity: .85;
}

.hero-illus-cloud--1 {
    bottom: 8%;
    left: -5%;
    animation-delay: 0s;
    animation-duration: 8s;
}

.hero-illus-cloud--2 {
    top: 12%;
    right: -2%;
    animation-delay: -3s;
    animation-duration: 6s;
    transform: scaleX(-1); /* Mirror */
    width: clamp(60px, 9vw, 110px);
    opacity: .6;
}

/* Float animations */
@keyframes heroFloat {
    0%, 100% { transform: translateY(0px); }
    50%       { transform: translateY(-14px); }
}
@keyframes cloudDrift {
    0%, 100% { transform: translateX(0) translateY(0); }
    50%       { transform: translateX(8px) translateY(-6px); }
}
.hero-illus-cloud--2 {
    animation-name: cloudDriftMirror;
}
@keyframes cloudDriftMirror {
    0%, 100% { transform: scaleX(-1) translateX(0) translateY(0); }
    50%       { transform: scaleX(-1) translateX(8px) translateY(-6px); }
}

/* Float cards positions relative to illustration */
.float-card--1 {
    position: absolute;
    top: 14%;
    right: -4%;
    z-index: 10;
}
.float-card--2 {
    position: absolute;
    bottom: 10%;
    left: -6%;
    z-index: 10;
}

/* ─── HERO TITLE: text-stroke fixed at source (line 136) ─── */

/* ─── HERO RESPONSIVE ─── */
@media(max-width: 1024px) {
    .hero-inner {
        grid-template-columns: 1fr 1fr;
        gap: 2.5rem;
        min-height: auto;
    }
}

@media(max-width: 768px) {
    .hero-inner {
        grid-template-columns: 1fr;
        text-align: center;
        gap: 2.5rem;
    }
    .hero-illustration {
        max-width: 320px;
        margin: 0 auto;
        order: -1; /* Illus trên, text dưới */
    }
    .float-card--1 {
        top: 5%;
        right: 0;
    }
    .float-card--2 {
        bottom: 5%;
        left: 0;
    }
    .hero-trust {
        justify-content: center;
    }
    .hero-actions {
        justify-content: center;
    }
    .hero-label {
        justify-content: center;
    }
}


/* WORK ITEMS BALANCE */
.work-item { display: flex !important; flex-direction: column !important; height: 100% !important; }
.work-info { display: flex !important; flex-direction: column !important; flex: 1 !important; }
.work-results { margin-top: auto !important; display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: .5rem !important; }
.work-info > p { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

.work-img img { height: 220px !important; }

/* ═══════════════════════════════════════
   PREMIUM FOOTER
   ═══════════════════════════════════════ */
.footer-premium {
    padding: 4.5rem 0 1.5rem;
    background: radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.85), rgba(246, 244, 240, 0.92));
    position: relative;
    overflow: hidden;
    margin-top: 1rem;
    border-top: 1px solid rgba(0, 0, 0, 0.04);
}

/* ─── Decorative Elements ─── */
.footer-divider-top {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,94,0,0.15) 20%, rgba(255,94,0,0.3) 50%, rgba(255,94,0,0.15) 80%, transparent);
    z-index: 3;
}

.footer-gradient-blur {
    position: absolute;
    bottom: -150px;
    right: -100px;
    width: 600px;
    height: 400px;
    background: radial-gradient(ellipse at center, rgba(255,94,0,0.06), transparent 60%);
    filter: blur(40px);
    pointer-events: none;
    z-index: 1;
}

.footer-premium .container {
    position: relative;
    z-index: 2;
}

/* ─── Grid Layout ─── */
.footer-grid {
    display: flex;
    justify-content: space-between;
    gap: 4rem;
    margin-bottom: 3rem;
    align-items: flex-start;
}

/* ─── Brand Section ─── */
.footer-brand {
    flex: 0 0 320px;
}

.footer-brand-logo {
    height: 54px;
    margin-bottom: 1.25rem;
    filter: brightness(0);
}

.footer-tagline {
    font-size: 0.9rem;
    line-height: 1.65;
    color: var(--text-2);
    margin-bottom: 2rem;
    max-width: 300px;
}

/* ─── Social Icons ─── */
.footer-socials {
    display: flex;
    gap: 0.75rem;
}

.social-icon {
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.8);
    color: var(--text-2);
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 2px 8px rgba(0,0,0,0.03), 0 1px 0 rgba(255,255,255,0.8) inset;
}

.social-icon:hover {
    background: rgba(255, 255, 255, 0.9);
    color: var(--accent);
    border-color: rgba(255,94,0,0.2);
    transform: translateY(-4px);
    box-shadow: 0 8px 16px rgba(255, 94, 0, 0.12), 0 0 12px rgba(255,94,0,0.08);
}

/* ─── Links Wrapper ─── */
.footer-links-wrapper {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    flex: 1;
    gap: 2rem;
}

/* ─── Columns & Typography ─── */
.footer-col h4 {
    font-size: 0.7rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--text);
    font-weight: 800;
    margin-bottom: 1.5rem;
}

.footer-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.footer-col li {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.footer-col a, .footer-col p {
    font-size: 0.9rem;
    color: var(--text-2);
    line-height: 1.4;
    margin: 0;
    transition: all 0.3s ease;
}

/* Link hover effect */
.footer-col:not(.footer-col--contact) a:hover {
    color: var(--accent);
    transform: translateX(6px);
}

.footer-col--contact a:hover {
    color: var(--accent);
}

/* ─── Contact Information ─── */
.contact-icon {
    flex-shrink: 0;
    color: var(--accent);
    opacity: 0.8;
}

.contact-link {
    font-weight: 500;
}

/* ─── Footer Bottom ─── */
.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    font-size: 0.8rem;
    color: var(--text-3);
}

.footer-legal {
    display: flex;
    gap: 2rem;
}

.footer-legal a {
    color: var(--text-3);
    transition: color 0.2s ease;
}

.footer-legal a:hover {
    color: var(--text-2);
}

/* ─── RESPONSIVE FOOTER ─── */
@media(max-width: 1024px) {
    .footer-grid {
        gap: 3rem;
    }
    .footer-brand {
        flex: 0 0 280px;
    }
}

@media(max-width: 991px) {
    .footer-grid {
        flex-direction: column;
        gap: 3.5rem;
    }
    .footer-brand {
        flex: auto;
        max-width: 100%;
    }
    .footer-tagline {
        max-width: 100%;
    }
    .footer-links-wrapper {
        width: 100%;
    }
}

@media(max-width: 768px) {
    .footer-premium {
        padding: 3.5rem 0 1.5rem;
    }
    .footer-links-wrapper {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }
    .footer-bottom {
        flex-direction: column;
        text-align: center;
        gap: 1rem;
        padding-top: 1.5rem;
    }
    .footer-legal {
        justify-content: center;
        gap: 1.5rem;
    }
}
