@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500;600&family=Nunito:wght@800&display=swap');

:root {
  --bg: #080810;
  --bg2: #0D0D1A;
  --bg3: #131325;
  --pink: #FF3CAC;
  --purple: #784BA0;
  --blue: #2B86C5;
  --gold: #FFD700;
  --white: #F5F2FF;
  --text: #D4D0EE;
  --muted: #ABA8CC;
  --subtle: #3A3660;
  --grad: linear-gradient(135deg,#FF3CAC,#784BA0,#2B86C5);
  --grad-text: linear-gradient(135deg,#FF3CAC 0%,#9B6FD4 50%,#2B86C5 100%);
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'DM Sans', sans-serif;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html{overflow-x:hidden}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:18px;line-height:1.75;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:24px 60px;display:flex;align-items:center;justify-content:space-between;transition:all .4s ease}
/* Inner pages always show nav bg */
body.inner-page .nav{background:rgba(8,8,16,.97);backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,.07)}
.nav.scrolled{padding:16px 60px;background:rgba(8,8,16,.97);backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,.07)}

/* LOGO — footer style in header */
.nav-logo{display:flex;align-items:center;gap:14px;text-decoration:none;flex-shrink:0}
.logo-grid{display:grid;grid-template-columns:repeat(3,11px);grid-template-rows:repeat(3,11px);gap:3px;flex-shrink:0}
.logo-grid .b{border-radius:2px}
.logo-wordmark{display:flex;flex-direction:column;line-height:1;gap:4px}
.logo-name{font-family:'Nunito','DM Sans',sans-serif;font-size:22px;font-weight:800;letter-spacing:3px;text-transform:uppercase;display:flex;align-items:baseline}
.logo-pix{font-family:'Nunito','DM Sans',sans-serif;font-size:22px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:#FFD200;-webkit-text-fill-color:#FFD200}
.logo-alpha{font-family:'Nunito','DM Sans',sans-serif;font-size:22px;font-weight:800;letter-spacing:3px;text-transform:uppercase;background:linear-gradient(90deg,#FF3CAC 0%,#9B59B6 55%,#7BA7D4 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo-studio{font-family:var(--font-body);font-size:10px;font-weight:800;letter-spacing:8px;text-transform:uppercase;color:#F5F2FF;opacity:1}

.nav-links{display:flex;align-items:center;gap:36px}
.nav-links a{color:#B8B5D5;text-decoration:none;font-size:14px;letter-spacing:2px;text-transform:uppercase;font-weight:500;transition:color .3s;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--white)}
.nav-cta{border:1px solid rgba(255,60,172,.4)!important;color:var(--pink)!important;padding:10px 26px!important;border-radius:2px;transition:all .3s!important}
.nav-cta:hover{background:rgba(255,60,172,.08)!important}
.nav-burger{display:none;background:none;border:none;color:var(--white);font-size:26px;cursor:pointer;padding:4px 8px;line-height:1}
.nav-mobile{display:none;position:fixed;top:0;left:0;right:0;z-index:998;flex-direction:column;background:rgba(8,8,16,.99);padding:90px 40px 48px;backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,.06)}
.nav-mobile.open{display:flex}
.nav-mobile a{color:var(--text);text-decoration:none;padding:18px 0;font-size:20px;border-bottom:1px solid rgba(255,255,255,.06);letter-spacing:1px;transition:color .2s;font-weight:400}
.nav-mobile a:last-child{border-bottom:none;color:var(--pink);font-weight:500}
.nav-mobile a:hover{color:var(--white)}

/* ── HERO ── */
.hero{min-height:100vh;display:grid;grid-template-columns:55% 45%;position:relative;overflow:hidden}
.hero-left{display:flex;align-items:center;padding:160px 72px 100px 60px;position:relative;z-index:2}
.hero-right{position:relative;overflow:hidden;min-height:100vh;background:#04040f}
.hero-texture{position:absolute;inset:0;background:linear-gradient(160deg,#0C0C20 0%,#080D1E 50%,#060B18 100%)}
.hero-texture::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(120,75,160,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(120,75,160,.06) 1px,transparent 1px);background-size:52px 52px}
.hero-geo{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1}
.hero-geo svg{width:85%;height:85%}
.hero-glow-1{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(120,75,160,.2) 0%,transparent 65%);top:10%;right:10%;pointer-events:none;z-index:1}
.hero-glow-2{position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(43,134,197,.15) 0%,transparent 65%);bottom:5%;left:20%;pointer-events:none;z-index:1}
.hero-fade-left{position:absolute;top:0;left:0;width:280px;height:100%;background:linear-gradient(to right,var(--bg) 0%,rgba(8,8,16,.85) 30%,rgba(8,8,16,.5) 55%,rgba(8,8,16,.15) 78%,transparent 100%);z-index:10;pointer-events:none}
.hero-inner{position:relative;z-index:1;max-width:620px}
.hero-eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:36px;opacity:0;animation:fadeUp .8s ease forwards .2s}
.hero-eyebrow-line{width:40px;height:1px;background:var(--pink);flex-shrink:0}
.hero-eyebrow span{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);font-weight:500}
.hero-title{font-family:var(--font-display);font-size:clamp(56px,6vw,96px);font-weight:300;line-height:1.0;letter-spacing:-2px;margin-bottom:32px;color:var(--white);opacity:0;animation:fadeUp .9s ease forwards .4s}
.hero-title em{font-style:italic;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:20px;font-weight:400;color:var(--text);max-width:500px;line-height:1.8;margin-bottom:52px;opacity:0;animation:fadeUp .9s ease forwards .6s}
.hero-sub strong{color:var(--white);font-weight:600}
.hero-actions{display:flex;align-items:center;gap:28px;flex-wrap:wrap;opacity:0;animation:fadeUp .9s ease forwards .8s}

/* ── BUTTONS ── */
.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:17px 40px;background:var(--grad);color:#fff;font-family:var(--font-body);font-size:14px;font-weight:600;letter-spacing:2px;text-transform:uppercase;text-decoration:none;border:none;border-radius:2px;cursor:pointer;transition:opacity .3s,transform .3s;white-space:nowrap}
.btn-primary:hover{opacity:.85;transform:translateY(-2px)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;color:var(--text);font-size:15px;letter-spacing:1px;text-transform:uppercase;text-decoration:none;transition:color .3s;font-weight:500;border:none;background:none;cursor:pointer;font-family:var(--font-body)}
.btn-ghost:hover{color:var(--white)}
.btn-ghost::after{content:'→';transition:transform .3s;display:inline-block}
.btn-ghost:hover::after{transform:translateX(4px)}
.btn-outline{display:inline-flex;align-items:center;padding:16px 36px;background:transparent;color:var(--white);font-family:var(--font-body);font-size:14px;font-weight:500;letter-spacing:2px;text-transform:uppercase;text-decoration:none;border:1px solid rgba(255,255,255,.2);border-radius:2px;cursor:pointer;transition:all .3s}
.btn-outline:hover{border-color:var(--pink);color:var(--pink)}

/* ── SECTIONS ── */
.section{padding:110px 60px;max-width:1280px;margin:0 auto}
.section-divider{max-width:1280px;margin:0 auto;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent)}
.section-label{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.section-label::before{content:'';width:32px;height:1px;background:var(--pink);flex-shrink:0}
.section-label span{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);font-weight:600}
.section-title{font-family:var(--font-display);font-size:clamp(40px,4vw,68px);font-weight:300;letter-spacing:-1px;line-height:1.08;margin-bottom:24px;color:var(--white)}
.section-title em{font-style:italic;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-body{font-size:19px;color:var(--text);line-height:1.85;margin-bottom:56px}

/* ── LOCAL STRIP ── */
.local-strip{border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07);padding:22px 60px;display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;background:rgba(255,255,255,.015)}
.local-strip span{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:#C0BCD8}
.local-strip strong{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:#E0DCFA;font-weight:500}
.local-sep{width:1px;height:12px;background:#3A3660;flex-shrink:0}

/* ── SERVICES ── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.07);align-items:stretch}
.service-item{background:var(--bg);padding:56px 48px;transition:background .4s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.service-item::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--grad);transform:scaleX(0);transition:transform .4s ease;transform-origin:left}
.service-item:hover{background:var(--bg3)}
.service-item:hover::after{transform:scaleX(1)}
.service-num{font-size:11px;letter-spacing:3px;color:#C0BCD8;margin-bottom:28px;display:block;font-weight:600}
.service-name{font-family:var(--font-display);font-size:34px;font-weight:400;margin-bottom:18px;line-height:1.15;color:var(--white)}
.service-desc{font-size:17px;color:var(--text);line-height:1.85}
.service-price{margin-top:32px;font-size:13px;letter-spacing:2px;color:var(--pink);text-transform:uppercase;font-weight:600}

/* ── PORTFOLIO ── */
.portfolio-section{border:1px solid rgba(255,255,255,.07);overflow:hidden}
.portfolio-inner{display:grid;grid-template-columns:1fr 1fr}
.portfolio-left{padding:72px 60px;border-right:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;justify-content:center}
.portfolio-right{position:relative;overflow:hidden;min-height:560px;background:var(--bg);display:flex;align-items:flex-end}
.portfolio-img{width:100%;height:100%;object-fit:cover;object-position:center bottom;display:block;position:absolute;inset:0}
.portfolio-img-fade{position:absolute;inset:0;background:linear-gradient(to right,rgba(8,8,16,.3) 0%,transparent 40%,transparent 85%,rgba(8,8,16,.6) 100%),linear-gradient(to top,rgba(8,8,16,.7) 0%,transparent 50%)}
.portfolio-tag{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--blue);margin-bottom:20px;display:block;font-weight:600}
.portfolio-title{font-family:var(--font-display);font-size:clamp(32px,3vw,50px);font-weight:300;line-height:1.15;margin-bottom:24px;color:var(--white)}
.portfolio-body{font-size:17px;color:var(--text);line-height:1.85;margin-bottom:36px}
.portfolio-list{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:40px}
.portfolio-list li{display:flex;align-items:flex-start;gap:14px;font-size:16px;color:var(--text);line-height:1.6}
.portfolio-list li::before{content:'';width:20px;height:1px;background:var(--pink);flex-shrink:0;margin-top:12px}
.portfolio-label{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--white);font-weight:600;padding:0 60px 32px;position:relative;z-index:2;font-family:var(--font-display);font-size:22px;letter-spacing:-0.5px;font-weight:300}

/* ── PRICING ── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.07);margin-top:56px}
.pricing-card{background:var(--bg);padding:56px 44px;position:relative;transition:background .3s;display:flex;flex-direction:column}
.pricing-card:hover{background:var(--bg3)}
.pricing-card.featured{background:var(--bg2);box-shadow:inset 0 0 0 1px rgba(255,60,172,.35),0 0 60px rgba(255,60,172,.1),0 0 120px rgba(120,75,160,.08)}
.pricing-badge{display:none}
.pricing-name{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:#C0BCD8;margin-bottom:16px;display:block;font-weight:600}
.pricing-price{font-family:var(--font-display);font-size:76px;font-weight:300;letter-spacing:-3px;line-height:1;margin-bottom:6px;color:var(--white)}
.pricing-price sup{font-size:32px;letter-spacing:0;vertical-align:top;margin-top:16px;font-weight:300}
.pricing-note{font-size:14px;color:#B8B4D4;margin-bottom:36px;line-height:1.5}
.pricing-feats{list-style:none;margin-bottom:44px;flex:1}
.pricing-feats li{font-size:16px;color:#D4D0EE;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:flex-start;gap:14px;line-height:1.5}
.pricing-feats li::before{content:'·';color:var(--pink);font-size:13px;flex-shrink:0;margin-top:1px}
.pricing-btn{display:block;text-align:center;padding:16px 24px;font-size:13px;letter-spacing:3px;text-transform:uppercase;text-decoration:none;font-family:var(--font-body);font-weight:600;border-radius:2px;transition:all .3s;margin-top:auto}
.pricing-btn-solid{background:var(--grad);color:#fff;border:none}
.pricing-btn-solid:hover{opacity:.85}
.pricing-btn-border{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.2)}
.pricing-btn-border:hover{border-color:var(--pink);color:var(--pink)}

/* ── TEAM ── */
.team-section{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.team-text{font-size:17px;color:var(--text);line-height:1.85;margin-bottom:20px}
.team-creds{display:flex;flex-direction:column;gap:12px;margin-top:32px;margin-bottom:40px}
.cred{display:flex;align-items:center;gap:14px;font-size:16px;color:#D4D0EE;line-height:1.5}
.cred::before{content:'';width:22px;height:1px;background:var(--purple);flex-shrink:0}
.team-persons{display:flex;flex-direction:column;gap:48px}
.person{display:grid;grid-template-columns:160px 1fr;gap:32px;align-items:start}
.person-photo{width:160px;aspect-ratio:3/4;object-fit:cover;object-position:center top;display:block;filter:grayscale(10%);transition:filter .4s}
.person:hover .person-photo{filter:grayscale(0%)}
.person-name{font-family:var(--font-display);font-size:36px;font-weight:300;letter-spacing:-.5px;margin-bottom:6px;color:var(--white)}
.person-role{font-size:12px;letter-spacing:3px;text-transform:uppercase;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px;display:block;font-weight:700}
.person-bio{font-size:16px;color:#D4D0EE;line-height:1.85}
.person-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.person-tag{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text);border:1px solid rgba(255,255,255,.15);padding:5px 12px;border-radius:1px;font-weight:400}

/* ── CTA ── */
.cta-section{padding:120px 60px;position:relative;overflow:hidden}
.cta-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.cta-left{position:relative;z-index:1}
.cta-right{position:relative;z-index:1}
.cta-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:500px;background:radial-gradient(ellipse,rgba(120,75,160,.08),transparent 70%);pointer-events:none}
.cta-label{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:24px;display:block;font-weight:600}
.cta-title{font-family:var(--font-display);font-size:clamp(40px,4.5vw,72px);font-weight:300;letter-spacing:-1px;line-height:1.08;color:var(--white)}
.cta-title em{font-style:italic;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cta-sub{font-size:18px;color:var(--text);margin-bottom:40px;line-height:1.85}
.cta-actions{display:flex;align-items:center;gap:28px;flex-wrap:wrap;margin-bottom:24px}
.cta-contact{font-size:15px;color:#B8B5D5}
.cta-contact a{color:#B8B5D5;text-decoration:none;transition:color .2s}
.cta-contact a:hover{color:var(--white)}

/* ── FOOTER ── */
.footer{border-top:1px solid rgba(255,255,255,.07);padding:48px 60px 32px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:40px}
.footer-logo{display:flex;align-items:center;gap:14px;text-decoration:none;margin-bottom:12px;flex-wrap:nowrap}
.footer-logo .logo-pix{font-size:24px;letter-spacing:4px;white-space:nowrap}
.footer-logo .logo-alpha{font-size:24px;letter-spacing:4px;white-space:nowrap}
.footer-logo .logo-studio{font-size:10px;letter-spacing:8px;opacity:1;white-space:nowrap;color:var(--white);font-weight:800}
.footer-logo .logo-grid{display:grid!important;grid-template-columns:repeat(3,12px)!important;grid-template-rows:repeat(3,12px)!important;gap:3px!important;flex-shrink:0}
.footer-logo .logo-grid .b{width:12px!important;height:12px!important;border-radius:2px!important}
.footer-tagline{font-size:15px;color:#B8B5D5}
.footer-nav{display:flex;gap:28px;justify-content:center;flex-wrap:nowrap;white-space:nowrap}
.footer-nav a{color:#B8B5D5;text-decoration:none;font-size:13px;letter-spacing:2px;text-transform:uppercase;transition:color .2s;font-weight:500;white-space:nowrap}
.footer-nav a:hover{color:var(--white)}
.footer-right{text-align:right}
.footer-social{display:flex;gap:20px;justify-content:flex-end;margin-bottom:10px;align-items:center}
.footer-social a{color:#B8B5D5;text-decoration:none;transition:color .2s;display:flex;align-items:center;line-height:1;opacity:.8}
.footer-social a:hover{color:var(--white);opacity:1}
.footer-copy{font-size:13px;color:rgba(200,196,220,.5)}

/* ── INNER PAGE HERO ── */
.page-hero{padding:160px 60px 80px;position:relative;overflow:hidden}
.page-hero-glow{position:absolute;top:-100px;right:-100px;width:50vw;height:50vw;background:radial-gradient(ellipse,rgba(120,75,160,.07),transparent 65%);pointer-events:none}
.page-hero-inner{max-width:1280px;margin:0 auto}

/* ── CONTACT ── */
.contact-layout{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start}
.contact-info-item{display:flex;flex-direction:column;gap:6px;padding:26px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.contact-info-item:first-of-type{border-top:1px solid rgba(255,255,255,.07)}
.contact-info-label{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:#C0BCD8;font-weight:600}
.contact-info-value{font-size:20px;color:var(--white);text-decoration:none;transition:color .2s;font-weight:400}
.contact-info-value:hover{color:var(--pink)}
.contact-form{display:flex;flex-direction:column;gap:32px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.form-group{display:flex;flex-direction:column;gap:12px}
.form-group label{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:#D4D0EE;font-weight:600}
.form-group input,.form-group textarea,.form-group select{background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.15);padding:14px 0;color:var(--white);font-family:var(--font-body);font-size:17px;outline:none;width:100%;transition:border-color .3s;border-radius:0}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--pink)}
.form-group textarea{resize:none;min-height:110px}
.form-group select option{background:#0D0D1A;color:var(--white)}
.form-group input::placeholder,.form-group textarea::placeholder{color:#8885A8;font-size:16px}

/* ── FAQ ── */
.faq-item{border-bottom:1px solid rgba(255,255,255,.07)}
.faq-item:first-child{border-top:1px solid rgba(255,255,255,.07)}
details summary{list-style:none;padding:24px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:18px;font-weight:500;color:var(--white);transition:color .2s;gap:20px}
details summary:hover{color:var(--white)}
details summary::-webkit-details-marker{display:none}
details summary::after{content:'+';color:var(--pink);font-size:22px;font-weight:300;flex-shrink:0;transition:transform .3s}
details[open] summary::after{transform:rotate(45deg)}
details p{font-size:17px;color:var(--text);line-height:1.85;padding-bottom:24px;max-width:620px}

/* ── CRED GRID ── */
.cred-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.07)}
.cred-cell{background:var(--bg);padding:22px 26px}
.cred-cell-label{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:600}
.cred-cell-value{font-size:15px;color:var(--text);line-height:1.5}
.cred-cell-value small{color:var(--muted);font-size:12px;display:block;margin-top:3px}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVE — FULLY QA'd
━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Large tablet */
@media(max-width:1100px){
  .nav{padding:22px 40px}
  .nav.scrolled{padding:15px 40px}
  .hero{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-left{padding:150px 40px 90px}
  .section{padding:90px 40px}
  .cta-section{padding:100px 40px}
  .cta-inner{grid-template-columns:1fr;gap:48px}
  .page-hero{padding:140px 40px 72px}
  .local-strip{padding:20px 40px}
  .footer{padding:56px 40px 36px}
  .services-grid{grid-template-columns:1fr 1fr}
  .pricing-grid{grid-template-columns:1fr}
  .pricing-card{padding:48px 40px}
  .portfolio-inner{grid-template-columns:1fr}
  .portfolio-right{min-height:420px}
  .portfolio-left{padding:56px 40px}
  /* Inline grids */
  [style*="grid-template-columns:1fr 1fr;gap:100px"],
  [style*="grid-template-columns:1fr 1fr;gap:80px"]{grid-template-columns:1fr!important;gap:48px!important}
  [style*="grid-template-columns:420px 1fr"],
  [style*="grid-template-columns:1fr 420px"],
  [style*="grid-template-columns:300px 1fr"],
  [style*="grid-template-columns:1fr 300px"]{grid-template-columns:1fr!important;gap:0!important}
  [style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr!important;gap:32px!important}
  [style*="min-height:600px"]{min-height:auto!important}
}

/* Tablet */
@media(max-width:800px){
  .nav{padding:20px 28px}
  .nav.scrolled{padding:14px 28px}
  .nav-links{display:none}
  .nav-burger{display:block}
  .hero-left{padding:130px 28px 80px}
  .section{padding:72px 28px}
  .section-divider{margin:0 28px}
  .cta-section{padding:80px 28px}
  .cta-inner{grid-template-columns:1fr;gap:36px}
  .local-strip{padding:18px 28px;gap:12px}
  .page-hero{padding:140px 28px 72px}
  .footer{grid-template-columns:1fr!important;gap:20px;padding:28px 28px 20px;text-align:center}
  .footer-social,.footer-nav{justify-content:center}
  .footer-right{text-align:center}
  .footer-logo{justify-content:center}
  .services-grid{grid-template-columns:1fr}
  .service-item{padding:44px 32px}
  .team-section{grid-template-columns:1fr;gap:56px}
  .contact-layout{grid-template-columns:1fr;gap:56px}
  .form-row{grid-template-columns:1fr;gap:32px}
  .portfolio-inner{grid-template-columns:1fr}
  .portfolio-left{padding:48px 28px}
  .portfolio-right{min-height:380px}
  /* All inline grids stack */
  [style*="grid-template-columns:1fr 1fr;gap:100px"],
  [style*="grid-template-columns:1fr 1fr;gap:80px"],
  [style*="grid-template-columns:1fr 1fr;gap:72px"],
  [style*="grid-template-columns:1fr 1fr;gap:64px"],
  [style*="grid-template-columns:1fr 1fr;gap:48px"]{grid-template-columns:1fr!important;gap:36px!important}
  [style*="grid-template-columns:420px 1fr"],
  [style*="grid-template-columns:1fr 420px"],
  [style*="grid-template-columns:300px 1fr"],
  [style*="grid-template-columns:1fr 300px"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:1fr 1fr 1fr"],[style*="grid-template-columns:repeat(3,1fr)"],[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr!important;gap:24px!important}
  /* About person grid */
  .about-person-grid{grid-template-columns:1fr!important;flex-direction:column}
  [style*="min-height:600px"]{min-height:auto!important}
  /* Credential rows */
  [style*="grid-template-columns:180px 1fr"]{grid-template-columns:1fr!important;gap:2px!important}
  /* Story section stat grid */
  [style*="grid-template-columns:1fr 1fr;gap:1px"]{grid-template-columns:1fr 1fr!important}
}

/* Mobile */
@media(max-width:520px){
  .nav{padding:18px 20px}
  .nav.scrolled{padding:13px 20px}
  .hero-left{padding:110px 20px 64px}
  .hero-title{letter-spacing:-1px}
  .hero-sub{font-size:18px}
  .section{padding:60px 20px}
  .section-divider{margin:0 20px}
  .cta-section{padding:64px 20px}
  .local-strip{padding:14px 20px;gap:0}
  .page-hero{padding:100px 20px 56px}
  .footer{padding:24px 20px 16px}
  .service-item{padding:40px 24px}
  .pricing-card{padding:44px 28px}
  .cta-actions{flex-direction:column;align-items:center;gap:16px}
  .btn-primary,.btn-outline{width:100%;justify-content:center;text-align:center}
  .person{grid-template-columns:1fr}
  .person-photo,.person-photo-fade{width:100%;max-width:200px}
  .cta-sub{font-size:18px}
  .portfolio-right{min-height:280px}
  .portfolio-left{padding:40px 20px}
  .portfolio-img{object-position:center bottom!important;object-fit:contain!important;background:var(--bg2)}
  /* All inline 2-col grids */
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important;gap:28px!important}
  [style*="grid-template-columns:1fr 1fr;gap:1px"]{grid-template-columns:1fr!important;gap:1px!important}
  [style*="grid-template-columns:repeat(3"],[style*="grid-template-columns:repeat(4"]{grid-template-columns:1fr!important;gap:20px!important}
  [style*="grid-template-columns:180px 1fr"],[style*="grid-template-columns:160px 1fr"]{grid-template-columns:1fr!important;gap:2px!important}
  /* About person photo editorial */
  [style*="grid-template-columns:420px 1fr"] img,
  [style*="grid-template-columns:1fr 420px"] img{max-width:100%!important;max-height:320px!important;object-position:center 15%!important}
  /* Footer logo center */
  .footer-logo{justify-content:center}
  .footer-tagline{text-align:center}
  /* Services inline detail list */
  [style*="display:flex;flex-direction:column;gap:10px"]{gap:8px!important}
  /* Contact process boxes */
  [style*="grid-template-columns:repeat(3,1fr);gap:1px"]{grid-template-columns:1fr!important}
  /* Stat boxes in story section */
  [style*="grid-template-columns:1fr 1fr;gap:1px;background"]{grid-template-columns:1fr 1fr!important}
}

/* Extra small */
@media(max-width:380px){
  .hero-title{font-size:48px}
  .nav-logo .logo-pix,.nav-logo .logo-alpha{font-size:16px}
  .local-strip strong,.local-strip span{font-size:10px;letter-spacing:2px}
}

/* Local strip responsive */
.local-phone-only { display: none; }
.local-desktop { display: inline; }
.local-desktop-sep { display: inline-block; }
@media(max-width:600px){
  .local-desktop { display: none !important; }
  .local-desktop-sep { display: none !important; }
  .local-strip { justify-content: center; }
  .local-phone-only {
    display: inline !important;
    font-size: 12px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--text);
    font-weight: 500;
  }
}

/* ── ABOUT PAGE RESPONSIVE ── */
.about-intro-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 48px; }
.about-person-grid { display: grid; grid-template-columns: 420px 1fr; align-items: start; }
.about-person-grid-rev { grid-template-columns: 1fr 420px; }
.about-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; }
.cred-row { display: grid; grid-template-columns: 180px 1fr; gap: 24px; }

/* ── SERVICES PAGE RESPONSIVE ── */
.svc-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; }
.svc-stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.05); align-self: start; }
.svc-process-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.05); margin-top: 48px; }

@media(max-width:1100px){
  .about-intro-grid { grid-template-columns: 1fr !important; gap: 32px !important; }
  .about-person-grid { grid-template-columns: 1fr !important; }
  .about-person-grid-rev { grid-template-columns: 1fr !important; }
  .about-two-col { grid-template-columns: 1fr !important; gap: 48px !important; }
  .svc-two-col { grid-template-columns: 1fr !important; gap: 48px !important; }
  .svc-process-grid { grid-template-columns: 1fr !important; }
}

@media(max-width:800px){
  .about-intro-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .about-person-grid { grid-template-columns: 1fr !important; }
  .about-person-grid-rev { grid-template-columns: 1fr !important; }
  .about-two-col { grid-template-columns: 1fr !important; gap: 40px !important; }
  .svc-two-col { grid-template-columns: 1fr !important; gap: 40px !important; }
  .svc-stat-grid { grid-template-columns: 1fr 1fr !important; }
  .svc-process-grid { grid-template-columns: 1fr !important; }
  /* About person photo stacked - full width with max height */
  .about-person-grid > div:first-child img,
  .about-person-grid-rev > div:last-child img { max-height: 380px; object-fit: cover; width: 100%; }
  .cred-row { grid-template-columns: 1fr !important; gap: 4px !important; }
}

@media(max-width:520px){
  .about-intro-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  .about-two-col { grid-template-columns: 1fr !important; gap: 32px !important; }
  .svc-two-col { grid-template-columns: 1fr !important; gap: 32px !important; }
  .svc-stat-grid { grid-template-columns: 1fr 1fr !important; }
  .svc-process-grid { grid-template-columns: 1fr !important; }
  .cred-row { grid-template-columns: 1fr !important; gap: 2px !important; }
  /* Portfolio image on mobile - push down */
  .portfolio-img { object-position: center 25% !important; }
  .portfolio-right { min-height: 300px !important; }
}

/* Footer logo fix on mobile — center properly, hide pixel grid */
@media(max-width:800px){
  .footer { grid-template-columns: 1fr !important; text-align: center; gap: 16px; }
  .footer-brand { display: none !important; }  /* hide full logo block on mobile */
  .footer-logo-grid { display: none !important; }
  .footer-social { justify-content: center; }
  .footer-nav { justify-content: center; gap:16px; flex-wrap:wrap; }
  .footer-right { display: flex; flex-direction: column; align-items: center; }
}
@media(max-width:400px){
  .footer-logo .logo-pix, .footer-logo .logo-alpha { font-size: 20px; letter-spacing: 4px; }
  .footer-logo .logo-studio { font-size: 9px; letter-spacing: 6px; }
}

/* Portfolio mobile image fix */
@media(max-width:800px){
  .portfolio-right { min-height: 440px !important; background: #050510; }
  .portfolio-img { object-fit: contain !important; object-position: center bottom !important; background: #050510; }
  .portfolio-img-fade { background: linear-gradient(to right, rgba(8,8,16,.1) 0%, transparent 30%), linear-gradient(to top, rgba(8,8,16,.9) 0%, transparent 40%) !important; }
}
@media(max-width:520px){
  .portfolio-right { min-height: 380px !important; }
  .portfolio-img { object-fit: contain !important; object-position: center bottom !important; }
}

/* Valya section — photo above text on mobile */
@media(max-width:1100px){
  .about-person-grid-rev { grid-template-columns: 1fr !important; }
  .valya-photo { order: 1 !important; min-height: 380px; }
  .valya-content { order: 2 !important; padding: 48px 40px !important; }
}
@media(max-width:800px){
  .valya-photo { min-height: 340px; }
  .valya-content { padding: 48px 28px !important; }
}
@media(max-width:520px){
  .valya-photo { min-height: 300px; }
  .valya-content { padding: 40px 20px !important; }
}

/* About page hero - ensure enough top padding, no text behind nav */
.inner-page .page-hero { padding-top: 200px !important; }
@media(max-width:800px){
  .inner-page .page-hero { padding-top: 160px !important; }
}
@media(max-width:520px){
  .inner-page .page-hero { padding-top: 130px !important; }
}

/* ── ABOUT PAGE SPECIFIC FIXES ── */

/* Valya picture above text on mobile */
@media(max-width:800px){
  .valya-grid { display: flex !important; flex-direction: column !important; }
  .valya-grid > div:last-child { order: -1; }   /* photo moves to top */
  .valya-grid > div:first-child { order: 1; }   /* text stays below */
}

/* Page hero - enough top padding so content clears nav */
@media(max-width:800px){
  .page-hero { padding: 170px 28px 72px !important; }
}
@media(max-width:520px){
  .page-hero { padding: 150px 20px 60px !important; }
  /* About page intro strip */
  [style*="padding:48px 60px"] { padding: 32px 20px !important; }
  [style*="padding:48px 32px;background"] { padding-top: 32px !important; }
  [style*="padding:48px 32px"] { padding: 32px 20px !important; }
  /* About person content padding */
  [style*="padding:72px 64px"] { padding: 36px 20px !important; }
  [style*="padding:48px 32px;display:flex"] { padding: 32px 20px !important; }
}

/* Nav always solid on inner pages */
body.inner-page .nav {
  background: rgba(8,8,16,0.97) !important;
  backdrop-filter: blur(24px) !important;
  border-bottom: 1px solid rgba(255,255,255,0.07) !important;
}

@media(max-width:600px){
  .local-strip-hide-mobile { display: none !important; }
}

/* ── TEAM CARDS — homepage ── */
.team-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.06);
  margin-top: 8px;
}
.team-card {
  background: var(--bg);
  display: grid;
  grid-template-columns: 280px 1fr;
  transition: background 0.3s;
  position: relative;
  overflow: hidden;
}
.team-card:hover { background: var(--bg3); }
.team-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad);
  transform: scaleX(0);
  transition: transform 0.4s ease;
  transform-origin: left;
}
.team-card:hover::after { transform: scaleX(1); }

.team-card-photo {
  position: relative;
  overflow: hidden;
}
.team-card-photo img {
  width: 100%;
  height: 100%;
  min-height: 340px;
  object-fit: cover;
  object-position: center top;
  display: block;
  filter: grayscale(8%);
  transition: filter 0.4s, transform 0.5s;
}
.team-card:hover .team-card-photo img {
  filter: grayscale(0%);
  transform: scale(1.02);
}

.team-card-body {
  padding: 40px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.team-card-name {
  font-family: var(--font-display);
  font-size: 44px;
  font-weight: 300;
  letter-spacing: -1px;
  color: var(--white);
  margin-bottom: 8px;
  line-height: 1;
}
.team-card-role {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  background: var(--grad-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 20px;
}
.team-card-bio {
  font-size: 16px;
  color: #D4D0EE;
  line-height: 1.85;
  max-width: 380px;
}

/* Responsive */
@media(max-width:1100px){
  .team-cards { grid-template-columns: 1fr; }
  .team-card { grid-template-columns: 240px 1fr; }
}
@media(max-width:700px){
  .team-cards { background: none; border: none; gap: 24px; }
  .team-card {
    grid-template-columns: 1fr;
    border: 1px solid rgba(255,255,255,0.07);
  }
  .team-card-photo img { min-height: 280px; }
  .team-card-body { padding: 28px 28px 36px; }
  .team-card-name { font-size: 36px; }
}
@media(max-width:520px){
  .team-card-photo img { min-height: 240px; }
  .team-card-body { padding: 24px 20px 32px; }
  .team-card-name { font-size: 32px; }
  .team-card-bio { font-size: 15px; }
}

/* Team intro - full width 2 col */
.team-intro-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  margin-bottom: 56px;
}
@media(max-width:800px){
  .team-intro-grid { grid-template-columns: 1fr; gap: 0; }
  .team-intro-grid > div:first-child { margin-bottom: 20px; }
}

/* ── ABOUT PAGE MOBILE ── */

/* Hide stats cards on mobile */
@media(max-width:800px){
  .about-stats-section { display:none !important; }
}

/* About team cards — stack on mobile: photo full width on top, content below */
@media(max-width:800px){
  .about-person-card,
  .about-person-card-rev {
    grid-template-columns: 1fr !important;
    border: none !important;
    border-top: none !important;
  }
  /* Reversed card (Valya) — photo comes second in HTML, push it to top visually */
  .about-person-card-rev > div:last-child {
    order: -1;
  }
  .about-person-card img,
  .about-person-card-rev img {
    min-height: 320px !important;
    max-height: 420px !important;
  }
  /* Content padding — flush to page edges */
  .about-person-card > div:last-child,
  .about-person-card-rev > div:first-child {
    padding: 32px 0 !important;
  }
}

@media(max-width:520px){
  .about-person-card img,
  .about-person-card-rev img {
    min-height: 260px !important;
    max-height: 340px !important;
  }
  /* Credential grid rows — stack label above value */
  [style*="grid-template-columns:160px 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 2px !important;
  }
}

/* ── TEAM STRIP — homepage ── */
/* Desktop: flex row, photo left, text right */
.team-strip-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 40px;
}
.team-strip-card {
  display: flex;
  align-items: flex-start;
  gap: 24px;
}
.team-strip-card picture {
  display: block;
  flex-shrink: 0;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  overflow: hidden;
}
.team-strip-photo {
  width: 160px;
  height: 160px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  flex-shrink: 0;
  filter: grayscale(10%);
  display: block;
}
.team-strip-body {
  flex: 1;
  min-width: 0;
}
.team-strip-name {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 300;
  color: var(--white);
  line-height: 1;
  margin-bottom: 6px;
}
.team-strip-role {
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  background: var(--grad-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 10px;
  display: block;
  font-weight: 600;
}
.team-strip-bio {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.75;
}

/* Mobile: photo floats left, ALL text wraps around it magazine-style */
@media(max-width:800px){
  .team-strip-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .team-strip-card {
    display: block;          /* kill flex — float only works in block context */
    padding: 32px 0;
    border: none;            /* no card on mobile */
    background: transparent; /* no card bg on mobile */
    border-bottom: 1px solid rgba(255,255,255,0.07);
    overflow: hidden;        /* contain the float */
  }
  .team-strip-card:last-child { border-bottom: none; }
  .team-strip-card picture {
    float: left;             /* float the picture element */
    width: 100px;
    height: 100px;
    margin: 4px 18px 8px 0;
    flex-shrink: unset;
    border-radius: 50%;
    overflow: hidden;        /* clips the circular photo */
    display: block;
  }
  .team-strip-photo {
    width: 100px;
    height: 100px;
    float: none;             /* img inside picture — picture handles the float */
    margin: 0;
    flex-shrink: unset;
  }
  .team-strip-body {
    overflow: hidden;        /* BFC: makes text wrap around the float */
    display: block;
    width: auto;
  }
  .team-strip-name { font-size: 22px; }
  .team-strip-bio  { font-size: 13px; }
  /* Clearfix so card height contains the floated photo */
  .team-strip-card::after {
    content: '';
    display: table;
    clear: both;
  }
}

@media(max-width:520px){
  .team-strip-photo { width: 80px; height: 80px; }
  .team-strip-name  { font-size: 20px; }
}


/* Hide portfolio card border on mobile */
@media(max-width:800px){
  .portfolio-section { border: none !important; }
  .portfolio-left { padding: 36px 0 !important; }
}

/* Hide local strip entirely on mobile */
@media(max-width:600px){
  .local-strip { display: none !important; }
}

/* Section intro 2-col headers — stack on mobile */
@media(max-width:800px){
  [style*="grid-template-columns:1fr 1fr;gap:64px"]{
    grid-template-columns:1fr !important;
    gap:20px !important;
  }
}

/* ── PORTFOLIO CARD — single full-width card ── */
.portfolio-card {
  border: 1px solid rgba(255,255,255,0.07);
  overflow: hidden;
  background: var(--bg2);
}
.portfolio-card-body {
  padding: 56px 60px 64px;
  position: relative;
}
.portfolio-card-body::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--grad);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s ease;
}
.portfolio-card:hover .portfolio-card-body::after {
  transform: scaleX(1);
}
.portfolio-card-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 36px;
  background: transparent;
  color: var(--white);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 2px;
  cursor: pointer;
  transition: all 0.3s;
  margin-top: 4px;
}
.portfolio-card-btn:hover {
  border-color: var(--pink);
  color: var(--pink);
}
@media(max-width:800px){
  .portfolio-card-body { padding: 40px 28px 48px; }
}
@media(max-width:520px){
  .portfolio-card-body { padding: 32px 20px 40px; }
}

/* ── BLOG PREVIEW — homepage ── */
.blog-preview-grid {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 80px;
  align-items: start;
}
.blog-preview-left {
  position: sticky;
  top: 120px;
}
.blog-preview-right {
  border-top: 1px solid rgba(255,255,255,0.08);
}
.blog-row {
  display: block;
  padding: 28px 0;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  text-decoration: none;
  transition: background 0.2s;
}
.blog-row-last {
  border-bottom: none;
}
.blog-row:hover .blog-row-title {
  background: var(--grad-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.blog-row-cat {
  display: inline-block;
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--pink);
  font-weight: 600;
  margin-bottom: 10px;
}
.blog-row-title {
  display: block;
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 400;
  color: var(--white);
  line-height: 1.3;
  margin-bottom: 10px;
  transition: all 0.3s;
}
.blog-row-meta {
  display: block;
  font-size: 12px;
  letter-spacing: 1.5px;
  color: var(--muted);
  text-transform: uppercase;
}
@media(max-width:900px){
  .blog-preview-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .blog-preview-left { position: static; }
}
@media(max-width:520px){
  .blog-row { padding: 22px 0; }
  .blog-row-title { font-size: 20px; }
}


/* ── NAV PHONE NUMBER — clean text link style ── */
.nav-phone {
  color: var(--muted);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 1px;
  font-family: var(--font-body);
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding-left: 20px;
  margin-left: 4px;
  border-left: 1px solid rgba(255,255,255,0.12);
  transition: color 0.3s;
}
.nav-phone::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--pink);
  flex-shrink: 0;
}
.nav-phone:hover {
  color: var(--white);
}
/* Hide phone on small screens — burger takes over */
@media(max-width:900px) {
  .nav-phone { display: none; }
}

/* ── CREDENTIAL STRIP — homepage team section ── */
.cred-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 20px 0 36px;
}
.cred-pill {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--text);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  padding: 7px 16px;
  border-radius: 100px;
  white-space: nowrap;
  transition: border-color 0.3s;
}
.cred-pill:hover {
  border-color: rgba(255,60,172,0.4);
  color: var(--white);
}
@media(max-width:520px) {
  .cred-pill { font-size: 11px; padding: 6px 12px; }
}


/* ── TEAM STRIP CARDS — bordered ── */
/* ── TEAM STRIP CARDS — bordered on desktop only ── */
@media(min-width:801px){
  .team-strip-card {
    border: 1px solid rgba(255,255,255,0.07);
    background: var(--bg2);
    padding: 36px;
    transition: background 0.3s;
    position: relative;
    overflow: hidden;
  }
  .team-strip-card::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 2px;
    background: var(--grad);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s ease;
  }
  .team-strip-card:hover { background: var(--bg3); }
  .team-strip-card:hover::after { transform: scaleX(1); }
}

/* ── MINI CTA STRIP ── */
.mini-cta-strip {
  background: var(--bg2);
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  padding: 56px 60px;
}
.mini-cta-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.mini-cta-label {
  font-size: 11px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--pink);
  font-weight: 600;
  margin-bottom: 12px;
  display: block;
}
.mini-cta-title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 44px);
  font-weight: 300;
  color: var(--white);
  line-height: 1.15;
  margin-bottom: 12px;
}
.mini-cta-sub {
  font-size: 16px;
  color: var(--text);
  line-height: 1.85;
}
.mini-cta-actions {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: flex-start;
}
.mini-cta-contact {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 15px;
}
.mini-cta-contact a {
  color: var(--muted);
  text-decoration: none;
  transition: color 0.2s;
}
.mini-cta-contact a:hover { color: var(--white); }
.mini-cta-contact span { color: var(--subtle); }
.mini-cta-actions .btn-primary,
.mini-cta-actions .btn-ghost {
  display: inline-flex;
}
@media(max-width:900px) {
  .mini-cta-inner { grid-template-columns: 1fr; gap: 36px; }
}
@media(max-width:800px) {
  .mini-cta-strip { padding: 48px 28px; }
}
@media(max-width:520px) {
  .mini-cta-strip { padding: 40px 20px; }
  .mini-cta-actions { width: 100%; }
  .mini-cta-actions .btn-primary { width: 100%; justify-content: center; }
}


/* ══════════════════════════════════════════════════════
   QA FIXES — Mobile circles, CTA centering, contact info
   ══════════════════════════════════════════════════════ */

/* Perfect circles on ALL screen sizes — belt+suspenders */
.team-strip-card picture {
  border-radius: 50% !important;
  overflow: hidden !important;
}
.team-strip-photo {
  border-radius: 50% !important;
  display: block !important;
}

/* Mobile: enforce circle dimensions explicitly */
@media(max-width:800px){
  .team-strip-card picture {
    width: 100px !important;
    height: 100px !important;
    border-radius: 50% !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
  }
  .team-strip-photo {
    width: 100px !important;
    height: 100px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
  }
}
@media(max-width:520px){
  .team-strip-card picture {
    width: 80px !important;
    height: 80px !important;
  }
  .team-strip-photo {
    width: 80px !important;
    height: 80px !important;
  }
}

/* CTA mobile: phone/email center handled by existing 520px rules */


/* CTA section — email centered on mobile only */
@media(max-width:800px){
  .cta-contact {
    text-align: center;
  }
}
/* ── PORTFOLIO TEASER CARDS (homepage) ── */
.pf-teaser-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.pf-teaser-card {
  padding: 20px 24px;
  border: 1px solid rgba(255,255,255,0.07);
  background: var(--bg2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  height: 72px;
  overflow: hidden;
}
.pf-teaser-soon { opacity: 0.5; }
.pf-teaser-text {
  flex: 1;
  min-width: 0;
  overflow: hidden;
}
.pf-teaser-cat {
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 4px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pf-teaser-name {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 300;
  color: var(--white);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pf-teaser-arrow {
  color: var(--pink);
  font-size: 20px;
  text-decoration: none;
  flex-shrink: 0;
  line-height: 1;
}
.pf-teaser-label {
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  flex-shrink: 0;
  white-space: nowrap;
}

/* Mobile: scale down name font so all cards stay at fixed height */
@media(max-width:600px) {
  .pf-teaser-card { height: 68px; padding: 16px 18px; gap: 10px; }
  .pf-teaser-name { font-size: 16px; }
  .pf-teaser-cat  { font-size: 9px; letter-spacing: 2px; }
}
@media(max-width:380px) {
  .pf-teaser-name { font-size: 14px; }
}
