:root{--cream:#fbf7ed;--cream-warm:#f5ecdc;--cream-deep:#ede0c8;--sand:#e3d4b6;--bronze:#a8895c;--bronze-soft:#c4a87a;--bronze-deep:#856a40;--gold:#c9a961;--gold-light:#e3c98a;--gold-bright:#d9b870;--ink:#1a1a1a;--ink-soft:#3a342c;--muted:#786d5d;--line:#ddcfb5;--navy:#0c1f3d;--nav-h:88px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h)}::selection{background:var(--gold);color:var(--cream)}.marble-bg{background-color:var(--cream);background-image:radial-gradient(ellipse 80% 50% at 20% 30%,rgba(227,212,182,0.45) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 70%,rgba(217,197,165,0.35) 0%,transparent 60%),radial-gradient(ellipse 70% 45% at 50% 50%,rgba(245,236,220,0.6) 0%,transparent 80%)}body{font-family:'Cormorant Garamond','Georgia',serif;color:var(--ink-soft);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-weight:400;background:var(--cream);position:relative}body::before{content:'';position:fixed;inset:0;z-index:-1;background-color:var(--cream);background-image:radial-gradient(ellipse 90% 60% at 15% 20%,rgba(196,168,122,0.18) 0%,transparent 55%),radial-gradient(ellipse 70% 50% at 90% 40%,rgba(168,137,92,0.10) 0%,transparent 50%),radial-gradient(ellipse 80% 60% at 50% 90%,rgba(227,201,138,0.12) 0%,transparent 55%),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1600 1200' preserveAspectRatio='xMidYMid slice'><defs><filter id='m'><feTurbulence type='fractalNoise' baseFrequency='0.012' numOctaves='2' seed='3'/><feDisplacementMap in='SourceGraphic' scale='28'/></filter></defs><g stroke='%23856a40' fill='none' filter='url(%23m)' stroke-linecap='round' opacity='0.10'><path d='M-100,200 C400,260 800,140 1200,240 S1600,300 1750,260' stroke-width='1.2'/><path d='M-100,540 C500,580 900,500 1300,560 S1700,640 1750,560' stroke-width='1'/><path d='M-100,900 C400,860 800,940 1200,880 S1700,820 1750,920' stroke-width='1.1'/></g><g stroke='%23c9a961' fill='none' filter='url(%23m)' stroke-linecap='round' opacity='0.07'><path d='M200,-50 Q220,300 180,600 T220,1300' stroke-width='0.8'/><path d='M700,-50 Q680,400 720,800 T700,1300' stroke-width='0.8'/><path d='M1100,-50 Q1080,300 1120,700 T1100,1300' stroke-width='0.8'/></g></svg>");background-size:cover,cover,cover,1600px 1200px;background-position:center;background-repeat:no-repeat,no-repeat,no-repeat,repeat}.ui,nav,button,input,textarea,select,label,.corner-mark{font-family:'Inter','Helvetica Neue',sans-serif;letter-spacing:0.16em}.values-tag{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;letter-spacing:0.2em;white-space:nowrap}.values-tag .dot{color:var(--gold);font-style:normal;margin:0 14px;font-weight:400}nav.top{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);padding:0 56px;display:flex;align-items:center;justify-content:space-between;background:rgba(251,247,237,0.92);backdrop-filter:blur(14px);border-bottom:1px solid rgba(168,137,92,0.2);box-shadow:0 1px 0 rgba(168,137,92,0.06),0 8px 24px -16px rgba(0,0,0,0.06)}.nav-left{display:flex;align-items:center;gap:20px}.nav-logo{width:60px;height:60px;background-image:url("../images/logo-gs.png");background-size:contain;background-repeat:no-repeat;background-position:center;flex-shrink:0;transition:transform 0.5s ease}.nav-logo:hover{transform:rotate(-12deg) scale(1.05)}.nav-brand-block{display:flex;flex-direction:column;line-height:1;gap:8px}.nav-brand-title{font-family:'Cormorant Garamond','Georgia',serif;font-style:italic;font-size:30px;letter-spacing:0.16em;font-weight:500;text-transform:uppercase;background:linear-gradient(90deg,var(--bronze-deep) 0%,var(--gold-light) 50%,var(--bronze-deep) 100%);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;position:relative;display:inline-block;animation:shimmer 8s linear infinite;line-height:1}.nav-brand-title::before{content:'Golden Studio';position:absolute;inset:0;-webkit-text-stroke:0.5px var(--navy);-webkit-text-fill-color:transparent;z-index:-1;opacity:0.7}@keyframes shimmer{to{background-position:200% center}}.nav-brand-tag{font-size:15px;color:var(--bronze-deep)}.nav-center{display:flex;gap:38px;align-items:center;color:var(--ink-soft)}.nav-center a{color:inherit;text-decoration:none;font-size:11px;letter-spacing:0.32em;text-transform:uppercase;font-weight:400;transition:color 0.25s;position:relative;padding:4px 0}.nav-center a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--gold);transition:width 0.35s ease}.nav-center a:hover{color:var(--bronze-deep)}.nav-center a:hover::after{width:100%}.nav-right{display:flex;align-items:center;gap:22px;color:var(--ink-soft)}.ig-link{width:42px;height:42px;border:1px solid currentColor;border-radius:50%;display:flex;align-items:center;justify-content:center;color:inherit;transition:all 0.4s;opacity:0.85}.ig-link:hover{background:var(--gold);color:var(--cream);border-color:var(--gold);transform:scale(1.08);opacity:1}.ig-link svg{width:17px;height:17px}.nav-right .lang{color:inherit;text-decoration:none;font-family:'Inter',sans-serif;font-size:11px;letter-spacing:0.32em;text-transform:uppercase;opacity:0.85}.nav-right .lang:hover{opacity:1;color:var(--bronze-deep)}.hero{margin-top:var(--nav-h);height:calc(100vh - var(--nav-h));min-height:640px;position:relative;overflow:hidden;color:var(--cream);background:#161310}.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;animation:heroZoom 24s ease-in-out infinite alternate;will-change:transform;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:translateZ(0);-webkit-transform:translateZ(0);contain:paint;pointer-events:none}@keyframes heroZoom{from{transform:scale(1)}to{transform:scale(1.06)}}.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,16,12,0.28) 0%,rgba(20,16,12,0.05) 28%,rgba(20,16,12,0.10) 55%,rgba(20,16,12,0.65) 100%);z-index:1}.hero-content{position:relative;z-index:4;height:100%;padding:56px 80px;display:flex;flex-direction:column;justify-content:flex-end}.hero-text{max-width:1100px}.hero-eyebrow{color:var(--gold-light);font-family:'Inter',sans-serif;font-size:11px;letter-spacing:0.5em;text-transform:uppercase;margin-bottom:26px;font-weight:400;text-shadow:0 2px 10px rgba(0,0,0,0.6);display:inline-flex;align-items:center;gap:16px;opacity:0;animation:fadeUpHero 1.2s ease 0.3s forwards}.hero-eyebrow::before{content:'';width:36px;height:1px;background:var(--gold-light);opacity:0.7}.hero h1{font-family:'Italiana','Cormorant Garamond',serif;font-size:clamp(60px,10vw,156px);line-height:0.94;font-weight:400;letter-spacing:-0.01em;margin-bottom:26px;color:var(--cream);text-shadow:0 6px 32px rgba(0,0,0,0.75),0 2px 8px rgba(0,0,0,0.55)}.hero h1 .word{display:inline-block;opacity:0;transform:translateY(40px);animation:heroWord 1.2s cubic-bezier(0.2,0.7,0.2,1) forwards}.hero h1 .word:nth-child(1){animation-delay:0.5s}.hero h1 .word:nth-child(2){animation-delay:0.75s}@keyframes heroWord{to{opacity:1;transform:translateY(0)}}.hero h1 em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;background:linear-gradient(180deg,var(--gold-light) 0%,var(--gold-bright) 50%,var(--bronze) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 4px 18px rgba(0,0,0,0.6))}.hero-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:24px;color:var(--cream);max-width:580px;line-height:1.55;font-weight:400;text-shadow:0 2px 14px rgba(0,0,0,0.75);opacity:0;animation:fadeUpHero 1.2s ease 1.1s forwards;border-left:2px solid var(--gold-light);padding:4px 0 4px 20px}@keyframes fadeUpHero{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-scroll{position:absolute;bottom:48px;right:80px;display:flex;align-items:center;gap:14px;flex-direction:column;color:var(--gold-light);font-family:'Inter',sans-serif;font-size:9.5px;letter-spacing:0.5em;text-transform:uppercase;z-index:4;text-shadow:0 1px 6px rgba(0,0,0,0.5);opacity:0;animation:fadeUpHero 1.2s ease 1.4s forwards}.hero-scroll-line{width:1px;height:40px;background:linear-gradient(180deg,var(--gold-light),transparent);animation:scrollPulse 2.4s ease-in-out infinite}@keyframes scrollPulse{0%,100%{opacity:0.4;transform:scaleY(0.7)}50%{opacity:1;transform:scaleY(1)}}.section-head{text-align:center;margin-bottom:52px}.section-num{display:inline-flex;align-items:center;gap:14px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:16px;letter-spacing:0.22em;color:var(--bronze);margin-bottom:18px;text-transform:uppercase}.section-num::before,.section-num::after{content:'';width:28px;height:1px;background:var(--gold);opacity:0.7}.section-title{font-family:'Cinzel','Cormorant Garamond',serif;font-size:clamp(42px,5.6vw,78px);font-weight:500;letter-spacing:0.22em;text-transform:uppercase;line-height:1;margin-bottom:14px;color:var(--ink);background:linear-gradient(180deg,var(--bronze-deep) 0%,#5a4830 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.section-title.long{font-size:clamp(34px,4.4vw,60px);letter-spacing:0.16em}.section-tagline{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:23px;color:var(--bronze);letter-spacing:0.04em;margin-bottom:28px}.section-tagline::before,.section-tagline::after{content:'·';margin:0 14px;color:var(--gold);font-style:normal}.section-tagline strong{font-weight:700;color:var(--bronze-deep)}section.intro{padding:92px 88px 70px;text-align:center;background:transparent;position:relative}.intro-flourish{position:absolute;top:50%;transform:translateY(-50%);height:86%;width:80px;z-index:1;pointer-events:none;opacity:0.88}.intro-flourish.left{left:36px}.intro-flourish.right{right:36px;transform:translateY(-50%) scaleX(-1)}.intro-flourish svg{width:100%;height:100%;display:block}@keyframes flourishDrift{0%,100%{stroke-dashoffset:0;opacity:0.75}50%{stroke-dashoffset:-8;opacity:1}}.intro-flourish .wave-line{animation:flourishDrift 12s ease-in-out infinite}.intro-flourish .diamond-accent{transform-origin:center;animation:diamondPulse 4s ease-in-out infinite}.intro-flourish .diamond-accent.d2{animation-delay:1s}.intro-flourish .diamond-accent.d3{animation-delay:2s}@keyframes diamondPulse{0%,100%{opacity:0.75}50%{opacity:1}}.intro-video-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}.intro-video-bg video{width:100%;height:100%;object-fit:cover;opacity:0.18;filter:sepia(0.2) saturate(0.7)}.intro-video-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(251,247,237,0.4) 0%,rgba(251,247,237,0.95) 75%)}section.intro>*:not(.intro-video-bg):not(.intro-flourish){position:relative;z-index:2}.intro>h2{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(36px,4.6vw,60px);line-height:1.1;max-width:1000px;margin:0 auto 24px;letter-spacing:-0.012em;color:var(--ink)}.intro>h2 em{font-style:italic;color:var(--bronze-deep)}.intro-body{max-width:620px;margin:0 auto;font-size:20px;line-height:1.75;color:var(--ink-soft)}.brand-divider{margin:56px auto 0;width:100%;max-width:720px;display:flex;align-items:center;justify-content:center;gap:30px}.brand-divider .bar{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--bronze),transparent)}.brand-divider .text{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:21px;letter-spacing:0.2em;color:var(--bronze-deep);white-space:nowrap}.brand-divider .text .dot{color:var(--gold);margin:0 16px;font-style:normal}section.services{padding:90px 56px;background:linear-gradient(180deg,rgba(245,236,220,0.7) 0%,rgba(237,224,200,0.8) 100%);position:relative;overflow:hidden}.services::before,.services::after{content:'';position:absolute;top:50%;width:600px;height:600px;border:1px solid rgba(168,137,92,0.12);border-radius:50%;transform:translateY(-50%);pointer-events:none}.services::before{left:-240px}.services::after{right:-240px}.services-inner{max-width:1400px;margin:0 auto;position:relative;z-index:2}.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.pillar{background:rgba(251,247,237,0.7);backdrop-filter:blur(8px);padding:52px 32px 36px;text-align:center;position:relative;transition:all 0.5s cubic-bezier(0.4,0,0.2,1);border:1px solid rgba(168,137,92,0.18);overflow:hidden;display:flex;flex-direction:column;align-items:center}.pillar::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:60px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transition:width 0.5s}.pillar:hover{transform:translateY(-8px);box-shadow:0 30px 60px -20px rgba(133,106,64,0.25);border-color:var(--gold);background:rgba(251,247,237,0.92)}.pillar:hover::before{width:100%}.pillar .icon-wrap{width:96px;height:96px;margin:0 auto 28px;position:relative;display:flex;align-items:center;justify-content:center;transition:transform 0.6s cubic-bezier(0.34,1.56,0.64,1)}.pillar .icon-wrap::before{content:'';position:absolute;inset:0;border:1px solid var(--bronze);border-radius:50%;transition:all 0.5s}.pillar .icon-wrap::after{content:'';position:absolute;inset:-8px;border:1px solid rgba(201,169,97,0.22);border-radius:50%;transition:all 0.6s}.pillar:hover .icon-wrap{transform:scale(1.08)}.pillar:hover .icon-wrap::before{border-color:var(--gold);box-shadow:inset 0 0 0 4px rgba(201,169,97,0.05)}.pillar:hover .icon-wrap::after{inset:-16px;border-color:var(--gold)}.pillar .icon-wrap svg{width:52px;height:52px;color:var(--bronze-deep);transition:all 0.6s;position:relative;z-index:2}.pillar:hover .icon-wrap svg{color:var(--gold);filter:drop-shadow(0 4px 8px rgba(201,169,97,0.3))}.pillar .roman{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--bronze);font-size:15px;letter-spacing:0.1em;margin-bottom:10px}.pillar h4{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:30px;line-height:1.1;margin-bottom:14px;color:var(--ink)}.pillar h4 em{font-style:italic;color:var(--bronze-deep)}.pillar p{font-size:17px;line-height:1.65;color:var(--ink-soft);max-width:280px;margin:0 auto 22px;flex:1}.pillar p em{font-style:italic;color:var(--bronze-deep);font-weight:500;white-space:nowrap}.pillar .pillar-link{font-family:'Inter',sans-serif;font-size:10.5px;letter-spacing:0.34em;text-transform:uppercase;color:var(--bronze-deep);text-decoration:none;font-weight:500;display:inline-flex;align-items:center;gap:8px;padding-bottom:4px;border-bottom:1px solid transparent;transition:all 0.3s}.pillar:hover .pillar-link{color:var(--gold);border-bottom-color:var(--gold);gap:14px}section.journey{background:transparent;padding:80px 56px 90px}.journey-grid{max-width:1500px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:minmax(0,auto);gap:22px}.journey-card{position:relative;overflow:hidden;cursor:pointer;background:var(--cream-warm);aspect-ratio:4/5}.journey-card.tall{aspect-ratio:3/4}.journey-card.full-wide{grid-column:span 2;aspect-ratio:4/3}.journey-card.wide{grid-column:span 2;aspect-ratio:21/9}.journey-card .media{position:absolute;inset:0;transition:transform 1.6s cubic-bezier(0.2,0,0.2,1)}.journey-card:hover .media{transform:scale(1.04)}.journey-card .media img{width:100%;height:100%;object-fit:cover}.journey-card .overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(20,16,12,0.7) 100%);z-index:2}.journey-card .label-wrap{position:absolute;bottom:0;left:0;right:0;padding:32px 38px;z-index:3;color:var(--cream)}.journey-card .label-wrap .num{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;color:var(--gold-light);letter-spacing:0.06em;margin-bottom:8px}.journey-card .label-wrap h4{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(22px,2.4vw,34px);line-height:1.1;margin-bottom:8px}.journey-card .label-wrap h4 em{font-style:italic}.journey-card .label-wrap .sub{font-family:'Inter',sans-serif;font-size:10px;letter-spacing:0.34em;text-transform:uppercase;opacity:0.78}.journey-frame{position:absolute;inset:14px;border:1px solid rgba(247,241,230,0.22);z-index:2;transition:all 0.5s;pointer-events:none}.journey-card:hover .journey-frame{inset:20px;border-color:rgba(247,241,230,0.55)}section.expertise{padding:90px 56px 100px;background:linear-gradient(180deg,rgba(237,224,200,0.6) 0%,rgba(251,247,237,0.3) 100%);position:relative;overflow:hidden}.expertise-inner{max-width:1400px;margin:0 auto;position:relative;z-index:2}.compass-wrap{position:relative;width:100%;max-width:1200px;margin:0 auto;aspect-ratio:1}.compass-wrap svg.compass{width:100%;height:100%;display:block}.compass-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none;width:28%}.compass-center .label{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:0.4em;text-transform:uppercase;color:var(--bronze-deep);margin-bottom:6px;opacity:0.7}.compass-center .word{font-family:'Cinzel',serif;font-weight:500;font-size:clamp(28px,3.4vw,46px);color:var(--ink);letter-spacing:0.10em;line-height:1;background:linear-gradient(180deg,var(--bronze-deep) 0%,#5a4830 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-transform:uppercase}.compass-center .sub{margin-top:14px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(22px,2vw,28px);color:var(--bronze);letter-spacing:0.04em}.zone-spoke{cursor:pointer;transition:all 0.4s ease}.zone-spoke .ring-pulse{transform-origin:center;transform-box:fill-box;animation:zonePulse 3s ease-in-out infinite}.zone-spoke .ring-pulse.delay-1{animation-delay:0.4s}.zone-spoke .ring-pulse.delay-2{animation-delay:0.8s}.zone-spoke .ring-pulse.delay-3{animation-delay:1.2s}.zone-spoke .ring-pulse.delay-4{animation-delay:1.6s}.zone-spoke .ring-pulse.delay-5{animation-delay:2s}@keyframes zonePulse{0%,100%{transform:scale(1);opacity:0.5}50%{transform:scale(1.5);opacity:0}}.zone-spoke .spoke-line{stroke:var(--bronze);stroke-width:0.6;opacity:0.3;stroke-dasharray:3 3;transition:all 0.4s}.zone-spoke .spoke-dot{fill:var(--gold);stroke:var(--bronze-deep);stroke-width:1;transition:all 0.4s}.zone-spoke .spoke-name{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:24px;fill:var(--ink);transition:all 0.4s}.zone-spoke .spoke-tag{font-family:'Inter',sans-serif;font-size:10px;letter-spacing:0.32em;fill:var(--muted);text-transform:uppercase;opacity:0.7;transition:all 0.4s}.zone-spoke:hover .spoke-name{font-style:italic;fill:var(--bronze-deep)}.zone-spoke:hover .spoke-dot{fill:var(--gold-light);r:9}.zone-spoke:hover .spoke-line{opacity:0.8;stroke:var(--gold);stroke-dasharray:none}.zone-spoke:hover .spoke-tag{opacity:1;fill:var(--bronze-deep)}.compass-outer-ring{transform-origin:450px 450px;animation:compassRotate 120s linear infinite}@keyframes compassRotate{to{transform:rotate(360deg)}}section.founders{padding:90px 56px;background:transparent;text-align:center}.founders-pair{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.founder-solo{max-width:580px;margin:0 auto;text-align:center}.founder-solo .portrait{aspect-ratio:1;max-width:260px;margin:0 auto 28px;border-radius:50%;overflow:hidden;position:relative;border:1px solid var(--line);transition:transform 0.6s}.founder-solo:hover .portrait{transform:scale(1.04)}.founder-solo .portrait::after{content:'';position:absolute;inset:8px;border:1px solid rgba(168,137,92,0.4);border-radius:50%;pointer-events:none;z-index:2}.founder-solo .portrait img{width:100%;height:100%;object-fit:cover;object-position:center top}.founder-solo h3{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:36px;margin-bottom:24px;color:var(--ink)}.founder-solo .role{font-family:'Inter',sans-serif;font-size:11.5px;letter-spacing:0.34em;text-transform:uppercase;color:var(--bronze-deep);margin-bottom:24px}.founder-solo p{font-size:19px;line-height:1.7;color:var(--ink-soft);max-width:480px;margin:0 auto}section.contact{padding:80px 56px 90px;background:linear-gradient(180deg,rgba(237,224,200,0.6) 0%,rgba(245,236,220,0.7) 100%);text-align:center;position:relative;overflow:hidden}.contact::before{content:'';position:absolute;top:50%;left:50%;width:580px;height:580px;transform:translate(-50%,-50%);border:1px solid rgba(168,137,92,0.18);border-radius:50%;pointer-events:none}.contact::after{content:'';position:absolute;top:50%;left:50%;width:380px;height:380px;transform:translate(-50%,-50%);border:1px solid rgba(168,137,92,0.14);border-radius:50%;pointer-events:none}.contact-inner{position:relative;z-index:2;max-width:700px;margin:0 auto}.contact-lead{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:21px;color:var(--ink-soft);max-width:540px;margin:0 auto 36px;line-height:1.55}.contact-details{display:flex;justify-content:center;gap:56px;margin-bottom:32px;flex-wrap:wrap}.contact-item .lbl{font-family:'Inter',sans-serif;font-size:10.5px;letter-spacing:0.36em;text-transform:uppercase;color:var(--bronze-deep);margin-bottom:6px}.contact-item a{font-family:'Cormorant Garamond',serif;font-size:19px;color:var(--ink);text-decoration:none;transition:color 0.2s}.contact-item a:hover{color:var(--bronze)}.cta-button{display:inline-block;padding:17px 42px;background:var(--ink);color:var(--cream);border:1px solid var(--ink);font-family:'Inter',sans-serif;font-size:10.5px;letter-spacing:0.36em;text-transform:uppercase;font-weight:500;cursor:pointer;text-decoration:none;transition:all 0.4s}.cta-button:hover{background:var(--gold);border-color:var(--gold);color:var(--cream);letter-spacing:0.42em}.floating-cta{position:fixed;right:28px;bottom:28px;z-index:90;display:flex;align-items:center;gap:12px;padding:14px 24px 14px 18px;background:var(--ink);color:var(--cream);border:1px solid var(--gold);border-radius:999px;font-family:'Inter',sans-serif;font-size:11px;letter-spacing:0.28em;text-transform:uppercase;font-weight:500;cursor:pointer;transition:all 0.4s cubic-bezier(0.4,0,0.2,1);box-shadow:0 16px 40px -10px rgba(0,0,0,0.4);text-decoration:none;opacity:0;transform:translateY(20px);pointer-events:none}.floating-cta.visible{opacity:1;transform:translateY(0);pointer-events:auto}.floating-cta:hover{background:var(--gold);color:var(--cream);transform:translateY(-3px);box-shadow:0 20px 50px -10px rgba(201,169,97,0.5)}.floating-cta .dot{width:8px;height:8px;background:var(--gold);border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}.floating-cta:hover .dot{background:var(--cream)}@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(1.3)}}.modal-overlay{position:fixed;inset:0;background:rgba(20,16,12,0.7);backdrop-filter:blur(10px);z-index:200;display:flex;align-items:center;justify-content:center;padding:32px;opacity:0;pointer-events:none;transition:opacity 0.4s ease}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{background:var(--cream);max-width:580px;width:100%;padding:56px 52px 48px;position:relative;transform:scale(0.95) translateY(20px);transition:transform 0.5s cubic-bezier(0.34,1.56,0.64,1);max-height:92vh;overflow-y:auto;border:1px solid var(--line)}.modal-overlay.open .modal{transform:scale(1) translateY(0)}.modal::before{content:'';position:absolute;top:16px;left:16px;right:16px;bottom:16px;border:1px solid rgba(168,137,92,0.28);pointer-events:none}.modal-close{position:absolute;top:22px;right:22px;background:transparent;border:none;width:34px;height:34px;cursor:pointer;color:var(--ink);display:flex;align-items:center;justify-content:center;transition:color 0.3s,transform 0.3s;z-index:2}.modal-close:hover{color:var(--bronze);transform:rotate(90deg)}.modal-close svg{width:18px;height:18px}.modal-head{text-align:center;margin-bottom:28px}.modal-head .top-label{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--bronze);font-size:13px;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:14px;display:inline-flex;align-items:center;gap:12px}.modal-head .top-label::before,.modal-head .top-label::after{content:'';width:22px;height:1px;background:var(--gold);opacity:0.7}.modal-head h3{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:36px;line-height:1.05;color:var(--ink);margin-bottom:10px}.modal-head h3 em{font-style:italic;color:var(--bronze-deep)}.modal-head p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;color:var(--muted);line-height:1.5;max-width:360px;margin:12px auto 0}.modal-form{display:flex;flex-direction:column;gap:18px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}.form-field{display:flex;flex-direction:column;gap:6px;position:relative}.form-field label{font-family:'Inter',sans-serif;font-size:9.5px;letter-spacing:0.3em;text-transform:uppercase;color:var(--bronze-deep);font-weight:500}.form-field input,.form-field textarea{background:transparent;border:none;border-bottom:1px solid var(--line);padding:8px 0;font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink);transition:border-color 0.3s}.form-field input:focus,.form-field textarea:focus{outline:none;border-bottom-color:var(--bronze)}.form-field textarea{resize:vertical;min-height:60px}.custom-select{position:relative}.custom-select-trigger{background:transparent;border:none;border-bottom:1px solid var(--line);padding:8px 28px 8px 0;font-family:'Cormorant Garamond',serif;font-size:17px;color:var(--ink);width:100%;text-align:left;cursor:pointer;position:relative;transition:border-color 0.3s}.custom-select-trigger.placeholder{color:var(--muted);font-style:italic}.custom-select-trigger::after{content:'';position:absolute;right:4px;top:50%;width:8px;height:8px;border-right:1.5px solid var(--bronze-deep);border-bottom:1.5px solid var(--bronze-deep);transform:translateY(-65%) rotate(45deg);transition:transform 0.3s}.custom-select.open .custom-select-trigger::after{transform:translateY(-30%) rotate(225deg)}.custom-select.open .custom-select-trigger{border-bottom-color:var(--bronze)}.custom-select-options{position:absolute;top:calc(100%+6px);left:0;right:0;background:var(--cream);border:1px solid var(--line);box-shadow:0 12px 36px -8px rgba(0,0,0,0.18);z-index:10;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity 0.25s ease,transform 0.25s ease;overflow:hidden}.custom-select.open .custom-select-options{opacity:1;transform:translateY(0);pointer-events:auto}.custom-select-option{padding:14px 18px;font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--ink);cursor:pointer;transition:background 0.2s,color 0.2s,padding-left 0.3s;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(168,137,92,0.12)}.custom-select-option:last-child{border-bottom:none}.custom-select-option:hover{background:rgba(201,169,97,0.08);color:var(--bronze-deep);padding-left:24px;font-style:italic}.custom-select-option .roman{font-style:italic;color:var(--bronze);font-size:13px;min-width:24px}.form-submit{margin-top:14px;padding:16px 32px;background:var(--ink);color:var(--cream);border:none;font-family:'Inter',sans-serif;font-size:11px;letter-spacing:0.36em;text-transform:uppercase;font-weight:500;cursor:pointer;transition:background 0.3s}.form-submit:hover{background:var(--gold)}.form-disclaimer{text-align:center;margin-top:6px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13px;color:var(--muted)}.form-success{text-align:center;padding:20px 0;color:var(--bronze-deep);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;display:none}.modal.success .modal-form{display:none}.modal.success .form-success{display:block}footer{background:linear-gradient(180deg,var(--cream-warm) 0%,var(--cream-deep) 100%);color:var(--ink-soft);padding:64px 56px 36px;position:relative;overflow:hidden;border-top:1px solid rgba(168,137,92,0.28)}footer::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:240px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);z-index:3}.footer-marble{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:0.55}.footer-marble svg{width:100%;height:100%;display:block}.footer-inner{max-width:1500px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding-bottom:36px;border-bottom:1px solid rgba(168,137,92,0.3);flex-wrap:wrap;gap:28px;position:relative;z-index:2}.footer-brand-block{display:flex;align-items:center;gap:18px}.footer-logo{width:54px;height:54px;background-image:url("../images/logo-gs.png");background-size:contain;background-repeat:no-repeat;background-position:center}.footer-brand-text{line-height:1.1}.footer-brand-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:24px;letter-spacing:0.18em;background:linear-gradient(90deg,var(--bronze-deep) 0%,var(--gold) 50%,var(--bronze-deep) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-transform:uppercase}.footer-brand-tag{font-size:13px;color:var(--bronze-deep);margin-top:6px}.footer-brand-tag .dot{margin:0 12px;color:var(--gold)}.footer-links{display:flex;gap:32px;font-family:'Inter',sans-serif;font-size:10.5px;letter-spacing:0.28em;text-transform:uppercase}.footer-links a{color:var(--ink-soft);text-decoration:none;transition:all 0.3s;opacity:0.75;position:relative}.footer-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width 0.35s ease}.footer-links a:hover{color:var(--bronze-deep);opacity:1}.footer-links a:hover::after{width:100%}.footer-bottom{max-width:1500px;margin:28px auto 0;display:flex;justify-content:space-between;align-items:center;font-family:'Inter',sans-serif;font-size:10.5px;color:var(--muted);letter-spacing:0.22em;text-transform:uppercase;position:relative;z-index:2}.footer-bottom .madrid-stamp{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;color:var(--bronze);letter-spacing:0.08em;text-transform:none}.footer-bottom .madrid-stamp::before{content:'◆';color:var(--gold);margin-right:8px;font-size:10px;vertical-align:middle}.fade-up{opacity:0;transform:translateY(40px);transition:opacity 0.9s ease,transform 0.9s ease}.fade-up.visible{opacity:1;transform:translateY(0)}@media (max-width:1024px){:root{--nav-h:70px}nav.top{padding:0 20px}.nav-center{display:none}.nav-logo{width:46px;height:46px}.nav-brand-title{font-size:20px;letter-spacing:0.14em}.nav-brand-tag{font-size:12px;letter-spacing:0.15em}.nav-brand-tag .dot{margin:0 8px}.ig-link{width:36px;height:36px}.ig-link svg{width:14px;height:14px}.nav-right .lang{display:none}.hero{min-height:560px}.hero-content{padding:36px 24px}.hero h1{font-size:56px}.hero-sub{font-size:16px}.hero-scroll{right:24px;bottom:28px}.section-title{font-size:38px;letter-spacing:0.16em}.section-title.long{font-size:30px;letter-spacing:0.12em}.section-tagline{font-size:18px}.section-tagline::before,.section-tagline::after{display:none}section.intro,section.services,section.expertise,section.founders,section.contact{padding:64px 24px}section.journey{padding:48px 24px 56px}.journey-grid{grid-template-columns:1fr;gap:14px}.journey-card.full-wide,.journey-card.wide{grid-column:span 1;aspect-ratio:4/3}.pillars-grid{grid-template-columns:1fr}.pillar .icon-wrap{width:84px;height:84px}.pillar .icon-wrap svg{width:44px;height:44px}.founders-pair{grid-template-columns:1fr;gap:56px}.compass-center .word{font-size:24px}.intro-flourish{display:none}.footer-inner{flex-direction:column;text-align:center}.footer-bottom{flex-direction:column;gap:12px;text-align:center}.contact-details{gap:28px}.floating-cta{right:14px;bottom:14px;padding:12px 20px 12px 14px;font-size:10px}.modal{padding:48px 28px 32px}.form-row{grid-template-columns:1fr}.brand-divider{gap:14px}.brand-divider .text{font-size:14px;letter-spacing:0.14em}.brand-divider .text .dot{margin:0 8px}}
/* === Mobile/tablet overrides: keep EN toggle reachable and tidy floating CTA on narrow phones === */
@media (max-width: 1024px){nav.top .nav-right .lang{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 8px;font-size:11px;letter-spacing:0.18em;margin-right:6px}}
@media (max-width: 480px){.floating-cta{font-size:10px;padding:14px 22px;letter-spacing:0.18em}}

/* === MOBILE polish (v2) — covers nav alignment, hero scroll position,
       journey card heights, compass legibility, footer wordmark overflow === */
@media (max-width: 768px){
  /* Nav: EN + IG balanced */
  nav.top{padding-left:18px !important;padding-right:18px !important}
  nav.top .nav-right{gap:14px !important}
  nav.top .nav-right .lang{min-width:30px !important;height:30px !important;font-size:11px !important;padding:0 6px !important;margin:0 !important;letter-spacing:0.18em !important}
  nav.top .nav-right .ig-link{width:30px !important;height:30px !important}

  /* Hero: Descubrir centered, BELOW text — increase hero-content bottom padding so flex-end text sits above the absolute scroll cue */
  .hero-content{padding:36px 24px 110px !important}
  .hero-scroll{position:absolute !important;left:50% !important;right:auto !important;top:auto !important;bottom:36px !important;transform:translateX(-50%) !important;display:flex !important;flex-direction:row !important;writing-mode:horizontal-tb !important;align-items:center !important;justify-content:center !important;gap:14px !important;margin:0 !important;width:auto !important;max-width:none !important}
  .hero-scroll > span{font-size:10px !important;letter-spacing:0.32em !important}
  .hero-scroll-line{width:56px !important;height:1px !important;background:linear-gradient(to right,rgba(227,201,138,0.95),rgba(227,201,138,0)) !important;transform:none !important}

  /* Journey: full-wide card matches tall cards */
  .journey-card.full-wide{aspect-ratio:3/4 !important;height:auto !important}

  /* Compass: bigger labels, center text fits */
  .expertise-inner{padding-left:0 !important;padding-right:0 !important}
  .compass-wrap{max-width:none !important;width:100% !important;padding:0 !important}
  .compass{width:100% !important;height:auto !important;aspect-ratio:1 !important}
  .compass-center{width:80% !important;left:50% !important;top:50% !important;transform:translate(-50%,-50%) !important;text-align:center !important}
  .compass-center .word{font-size:22px !important;letter-spacing:0.06em !important;white-space:nowrap !important}
  .compass-center .sub{font-size:11px !important;letter-spacing:0.16em !important;white-space:normal !important;margin-top:8px !important}
  .compass text.spoke-name{font-size:38px !important}
  .compass text.spoke-tag{font-size:26px !important}
  .compass g text{font-size:32px}

  /* Footer: brand block stacks, everything centers, no overflow */
  .footer-inner{padding:0 18px 36px !important;align-items:center !important;gap:24px !important;flex-direction:column !important}
  .footer-brand-block{flex-direction:column !important;align-items:center !important;text-align:center !important;gap:12px !important;width:100% !important;max-width:100% !important}
  .footer-brand-text{text-align:center !important}
  .footer-brand-name{font-size:22px !important;white-space:normal !important}
  .footer-brand-tag{font-size:12px !important;letter-spacing:0.18em !important;white-space:normal !important;line-height:1.6 !important}
  .footer-links{justify-content:center !important;flex-wrap:wrap !important;gap:14px 20px !important;width:100% !important;padding:0 !important}
  .footer-bottom{flex-wrap:wrap !important;gap:10px !important;text-align:center !important;justify-content:center !important;padding:18px !important}
  .footer-bottom > div{width:100% !important}
}

/* === WhatsApp icon next to phone === */
.contact-item .whatsapp-link{display:inline-flex;align-items:center;gap:8px;margin-top:10px;font-family:'Inter','Helvetica Neue',sans-serif;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--bronze-deep);text-decoration:none;padding:6px 12px;border:1px solid var(--line);border-radius:999px;transition:background 0.25s,color 0.25s,border-color 0.25s}
.contact-item .whatsapp-link svg{width:16px;height:16px;color:#25d366}
.contact-item .whatsapp-link:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.contact-item .whatsapp-link:hover svg{color:var(--cream)}

/* === Custom select error state (when service not chosen) === */
.custom-select.error .custom-select-trigger{border-color:#b34a4a !important;color:#b34a4a !important}

/* === Submit button loading state === */
.form-submit[disabled]{opacity:0.6;cursor:wait}
.form-error{color:#b34a4a;font-size:13px;font-style:italic;text-align:center;margin-top:10px;display:none}
.form-error.show{display:block}

/* ============================================================
   v4 polish — IG bronze, lang+flag stack, WhatsApp below phone,
   mobile compass chips around the full circle
   ============================================================ */

/* === IG icon: solid bronze, much more visible === */
nav.top .ig-link{
  background:var(--bronze-deep)!important;
  border-color:var(--bronze-deep)!important;
  color:var(--cream)!important;
  opacity:1!important
}
nav.top .ig-link svg{stroke-width:2!important}
nav.top .ig-link:hover{
  background:var(--gold)!important;
  border-color:var(--gold)!important;
  color:var(--cream)!important
}

/* === Nav-right: stack IG + lang vertically, both centered === */
nav.top .nav-right{
  flex-direction:column;
  align-items:center;
  gap:8px
}

/* === Lang button: flag chip above the EN/ES label === */
nav.top .nav-right .lang{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  padding:4px 6px;
  line-height:1;
  border:none;
  background:none
}
nav.top .nav-right .lang-flag{
  width:22px;
  height:12px;
  display:inline-flex;
  border:1px solid rgba(168,137,92,0.5);
  border-radius:2px;
  overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,0.08)
}
nav.top .nav-right .lang-flag svg{width:100%;height:100%;display:block}
nav.top .nav-right .lang-label{
  font-family:'Inter',sans-serif;
  font-size:10px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--bronze-deep)
}
/* Show only the destination-language flag */
html[lang="es"] .nav-right .lang .flag-es{display:none}
html[lang="en"] .nav-right .lang .flag-us{display:none}

/* === WhatsApp link: full-row under the phone number, centered === */
.contact-item{display:flex;flex-direction:column;align-items:center;gap:4px}
.contact-item .whatsapp-link{
  display:inline-flex;
  margin-top:12px;
  align-self:center
}

/* ============================================================
   Mobile compass — replace SVG labels with HTML chips
   distributed at clock positions 12/2/4/6/8/10
   ============================================================ */
.compass-chips{display:none}

@media (max-width: 768px){
  /* Hide existing SVG spoke labels (they overflow on mobile) */
  .compass text.spoke-name,
  .compass text.spoke-tag{display:none!important}
  /* Soften the cardinal letters too (N/S/E/O get cropped) */
  .compass-outer-ring g text{display:none}

  /* Use bigger center text now that there's room */
  .compass-center .word{font-size:24px!important}

  /* Show the HTML chip overlay */
  .compass-chips{
    display:block;
    position:absolute;
    inset:0;
    pointer-events:none
  }
  .zone-chip{
    position:absolute;
    transform:translate(-50%,-50%);
    width:96px;
    text-align:center;
    pointer-events:auto
  }
  .zone-chip .z-name{
    font-family:'Cormorant Garamond',serif;
    font-style:italic;
    font-size:14px;
    font-weight:500;
    color:var(--ink);
    line-height:1.1
  }
  .zone-chip .z-tag{
    font-family:'Inter',sans-serif;
    font-size:8px;
    letter-spacing:0.16em;
    text-transform:uppercase;
    color:var(--bronze-deep);
    margin-top:4px;
    line-height:1.2
  }
  /* 6 clock-face positions; radius ~38% of compass-wrap from center */
  .pos-12{top:11%;left:50%}
  .pos-2 {top:31%;left:83%}
  .pos-4 {top:69%;left:83%}
  .pos-6 {top:90%;left:50%}
  .pos-8 {top:69%;left:17%}
  .pos-10{top:31%;left:17%}

  /* The small gold pulse dots still live in the SVG; reposition them visually
     by tightening the compass so they sit near the chip centers. The dots
     already form a hexagonal ring close to where the chips land. */
}

/* ============================================================
   v5 polish — safe-area notch padding, compass chip alignment
   ============================================================ */
@media (max-width: 768px){
  /* iOS notch / dynamic island: push nav content below the status bar */
  nav.top{
    padding-top:env(safe-area-inset-top,12px)!important;
    padding-bottom:8px!important;
    height:auto!important;
    min-height:var(--nav-h);
    align-items:center!important
  }
  /* Slight breathing room around the nav-right stack so IG stays inside */
  nav.top .nav-right{
    margin-top:env(safe-area-inset-top,0px);
    align-self:center
  }

  /* Compass chips now sit AT the same angles as the SVG dots so labels and
     dots line up — NE / E / SE / SW / W / NW (not clock positions) */
  .pos-12{top:35%!important;left:70%!important}   /* Salamanca (NE dot)   */
  .pos-2 {top:50%!important;left:75%!important}   /* Recoletos  (E dot)   */
  .pos-4 {top:65%!important;left:70%!important}   /* Justicia   (SE dot)  */
  .pos-6 {top:65%!important;left:30%!important}   /* Chamberí   (SW dot)  */
  .pos-8 {top:50%!important;left:25%!important}   /* Conde Orgaz(W dot)   */
  .pos-10{top:35%!important;left:30%!important}   /* La Moraleja(NW dot)  */

  /* Tighter chip width + nudge tag font so labels stay inside the circle */
  .zone-chip{width:88px!important}
  .zone-chip .z-name{font-size:13px!important}
  .zone-chip .z-tag{font-size:7.5px!important;letter-spacing:0.14em!important}

  /* Pull MADRID center slightly up so it doesn't conflict with chips */
  .compass-center{top:48%!important}
}

/* ============================================================
   v6 — Mobile compass redesign:
   - Hide all SVG spoke groups (dots, lines, ring-pulses, names, tags)
   - HTML chips at clock positions (12 / 2 / 4 / 6 / 8 / 10)
   - Push compass-wrap to nearly the full viewport
   - Tighten chip text so labels stay inside the circle
   ============================================================ */
@media (max-width: 768px){
  /* Make section padding ~0 so the compass can claim the screen */
  section.expertise{padding-left:0!important;padding-right:0!important}
  .expertise-inner{padding-left:0!important;padding-right:0!important;max-width:none!important;width:100%!important}

  /* Compass goes nearly edge-to-edge (8px breathing room each side) */
  .compass-wrap{
    width:calc(100vw - 16px)!important;
    max-width:calc(100vw - 16px)!important;
    margin-left:calc(50% - 50vw + 8px)!important;
    margin-right:calc(50% - 50vw + 8px)!important;
    padding:0!important
  }
  .compass{width:100%!important;height:auto!important;aspect-ratio:1!important}

  /* Hide the entire SVG spoke decoration on mobile — chips replace it */
  .compass .zone-spoke{display:none!important}

  /* Chips at clock positions, evenly distributed around the circle */
  .pos-12{top:14%!important;left:50%!important}    /* Salamanca   */
  .pos-2 {top:31%!important;left:82%!important}    /* Recoletos   */
  .pos-4 {top:69%!important;left:82%!important}    /* Justicia    */
  .pos-6 {top:86%!important;left:50%!important}    /* Chamberí    */
  .pos-8 {top:69%!important;left:18%!important}    /* Conde Orgaz */
  .pos-10{top:31%!important;left:18%!important}    /* La Moraleja */

  /* Compact, balanced chip typography */
  .zone-chip{width:104px!important;transform:translate(-50%,-50%)!important}
  .zone-chip .z-name{font-size:14px!important;line-height:1.15!important;color:var(--ink)!important}
  .zone-chip .z-tag{
    font-size:8px!important;
    letter-spacing:0.14em!important;
    line-height:1.3!important;
    margin-top:4px!important;
    color:var(--bronze-deep)!important
  }

  /* MADRID center stays small so it never collides with the side chips */
  .compass-center{top:50%!important;width:60%!important}
  .compass-center .word{font-size:22px!important;letter-spacing:0.08em!important}
  .compass-center .sub{font-size:10px!important;margin-top:6px!important;letter-spacing:0.12em!important}

  /* A small ring of gold dots at the clock positions for elegance —
     they replace the SVG spoke-dots we hid. Pure CSS pseudo-element. */
  .zone-chip::after{
    content:'';
    position:absolute;
    width:6px;
    height:6px;
    border-radius:50%;
    background:var(--gold);
    box-shadow:0 0 0 4px rgba(201,169,97,0.18);
    left:50%;
    bottom:-14px;
    transform:translateX(-50%);
    opacity:0.85
  }
  /* Move the dot ABOVE the chip for chips that sit at the bottom of the circle
     so it stays on the compass-perimeter side */
  .pos-4::after,.pos-6::after,.pos-8::after{top:-14px;bottom:auto}
}

/* ============================================================
   v7 — Compass MUCH bigger on mobile (edge-to-edge),
        kill the pseudo-element gold dots that were stranding inside,
        ensure SVG zone-spoke groups are fully hidden
   ============================================================ */
@media (max-width: 768px){
  /* Compass takes the FULL viewport width (no parent padding interference) */
  section.expertise{padding:40px 0!important;overflow:visible!important}
  .expertise-inner{padding:0!important;max-width:none!important;width:100%!important}
  .compass-wrap{
    width:100vw!important;
    max-width:100vw!important;
    margin-left:calc(50% - 50vw)!important;
    margin-right:calc(50% - 50vw)!important;
    padding:0!important;
    overflow:visible!important
  }
  .compass{
    width:100%!important;
    height:auto!important;
    aspect-ratio:1!important;
    display:block
  }

  /* Hide ALL SVG spoke decoration on mobile — chips replace it.
     Also kill the previous pseudo-element dots that were stranding inside */
  .compass .zone-spoke,
  .compass .zone-spoke *{display:none!important}
  .zone-chip::after,
  .zone-chip::before{display:none!important;content:none!important}

  /* Re-affirm chip positions at clock 12 / 2 / 4 / 6 / 8 / 10 */
  .pos-12{top:11%!important;left:50%!important}
  .pos-2 {top:30%!important;left:84%!important}
  .pos-4 {top:70%!important;left:84%!important}
  .pos-6 {top:89%!important;left:50%!important}
  .pos-8 {top:70%!important;left:16%!important}
  .pos-10{top:30%!important;left:16%!important}

  /* Slightly wider chips now that the compass is bigger */
  .zone-chip{width:108px!important}

  /* Centre stays compact and unobstructed */
  .compass-center{top:50%!important;width:55%!important}
  .compass-center .word{font-size:22px!important;letter-spacing:0.08em!important}
  .compass-center .sub{font-size:10px!important;margin-top:6px!important;white-space:nowrap!important}
}

/* ============================================================
   v8 — Bring spoke lines + dots BACK on mobile (re-positioned
        by main.js to point at the clock-position chips). Hide
        only the SVG text labels because the chips contain them.
   ============================================================ */
@media (max-width: 768px){
  /* Override the v7 blanket hide */
  .compass .zone-spoke{display:block!important}
  .compass .zone-spoke *{display:initial}

  /* Show the geometric decoration */
  .compass .zone-spoke .spoke-line,
  .compass .zone-spoke .spoke-dot,
  .compass .zone-spoke .ring-pulse{display:block!important;opacity:1!important}

  /* Hide the SVG text — the chips carry the zone name + tag */
  .compass .zone-spoke .spoke-name,
  .compass .zone-spoke .spoke-tag{display:none!important}

  /* Make the line + dot a touch more visible at this size */
  .compass .zone-spoke .spoke-line{stroke-width:2.5!important;opacity:0.85!important}
  .compass .zone-spoke .spoke-dot{r:9!important}

  /* Spokes sit BEHIND the chips */
  .compass .zone-spoke{pointer-events:none}
  .zone-chip{z-index:2!important}
}

/* ============================================================
   v13 — Footer with centered legal links + cookie banner
   ============================================================ */
.footer-bottom{display:grid !important;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px}
.footer-bottom > .footer-bottom-left{justify-self:start}
.footer-bottom > .footer-bottom-right{justify-self:end}
.footer-bottom > .footer-legal-links{justify-self:center;text-transform:none;letter-spacing:0.04em;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;color:var(--bronze);display:inline-flex;align-items:center;gap:0}
.footer-legal-links a{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:color .25s, border-color .25s;padding:2px 4px}
.footer-legal-links a:hover{color:var(--gold);border-bottom-color:var(--gold)}
.footer-legal-links .dot{margin:0 6px;color:var(--gold);opacity:0.75;font-style:normal}
@media (max-width: 768px){
  .footer-bottom{grid-template-columns:1fr !important;text-align:center !important;gap:10px !important}
  .footer-bottom > .footer-bottom-left,.footer-bottom > .footer-bottom-right,.footer-bottom > .footer-legal-links{justify-self:center}
  .footer-bottom-right{display:none}
}

/* Cookie consent banner */
.cookie-banner{
  position:fixed;
  left:50%;
  bottom:24px;
  transform:translateX(-50%) translateY(140%);
  width:min(720px, calc(100vw - 32px));
  background:rgba(251,247,237,0.97);
  border:1px solid rgba(133,106,67,0.28);
  border-radius:18px;
  box-shadow:0 22px 60px rgba(42,37,32,0.18), 0 2px 6px rgba(42,37,32,0.06);
  padding:18px 22px;
  z-index:9999;
  font-family:'Inter', sans-serif;
  color:var(--ink, #2a2520);
  font-size:13.5px;
  line-height:1.55;
  transition:transform .55s cubic-bezier(.16,.84,.32,1), opacity .35s ease;
  opacity:0;
  -webkit-backdrop-filter:blur(10px);
  backdrop-filter:blur(10px);
}
.cookie-banner.visible{transform:translateX(-50%) translateY(0);opacity:1}
.cookie-banner[hidden]{display:none}
.cookie-banner-inner{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.cookie-banner-text{flex:1 1 280px;min-width:0;color:#3a322a}
.cookie-banner-text a{color:var(--gold, #c9a961);text-decoration:underline;text-decoration-color:rgba(201,169,97,0.45);text-underline-offset:3px}
.cookie-banner-text a:hover{filter:brightness(1.1)}
.cookie-banner-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-btn{
  background:var(--gold, #c9a961);
  color:#fff;
  border:none;
  border-radius:24px;
  padding:11px 22px;
  font-size:11.5px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  font-family:inherit;
  font-weight:500;
  cursor:pointer;
  transition:filter .2s, transform .15s;
  white-space:nowrap;
}
.cookie-btn:hover{filter:brightness(1.08)}
.cookie-btn:active{transform:translateY(1px)}
.cookie-btn.secondary{background:transparent;color:#856a43;border:1px solid rgba(133,106,67,0.45)}
.cookie-btn.secondary:hover{border-color:var(--gold, #c9a961);color:var(--gold, #c9a961);filter:none}
@media (max-width:520px){
  .cookie-banner{bottom:12px;padding:16px 18px;width:calc(100vw - 16px);border-radius:14px}
  .cookie-banner-inner{flex-direction:column;align-items:stretch;gap:14px}
  .cookie-banner-actions{justify-content:flex-end}
  .cookie-btn{padding:10px 18px;font-size:11px}
}
