/* ============================================ */
/* PANELLA MUA — Styles                         */
/* Warm editorial palette, bold typography       */
/* ============================================ */

:root {
  --bg:       #0c0a08;
  --bg-alt:   #141210;
  --bg-warm:  #1a1510;
  --text:     #faf6f1;
  --text-dim: #9a8e82;
  --accent:   #c8a97d;
  --accent-2: #a67c52;
  --accent-3: #e8d5c0;
  --gold:     #d4af37;
  --surface:  #1c1916;
  --border:   rgba(200,169,125,0.1);
  --border-h: rgba(200,169,125,0.25);

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Outfit', -apple-system, sans-serif;

  --pad: clamp(20px, 5vw, 80px);
  --max: 1400px;
  --section: clamp(100px, 15vh, 180px);

  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.76, 0, 0.24, 1);
}

/* RESET */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:initial}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}
body{font-family:var(--sans);background:var(--bg);color:var(--text);overflow-x:hidden;cursor:none}
a{color:inherit;text-decoration:none;cursor:none}
button,input,textarea,select{font-family:inherit;cursor:none;color:var(--text)}
img{max-width:100%;display:block}
em{font-family:var(--serif);font-style:italic;color:var(--accent)}
::selection{background:var(--accent);color:var(--bg)}

/* ============================================ */
/* CURSOR                                       */
/* ============================================ */
.cursor{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;mix-blend-mode:difference}
.cursor__dot{position:absolute;width:8px;height:8px;background:#fff;border-radius:50%;transform:translate(-50%,-50%)}
.cursor__ring{position:absolute;width:40px;height:40px;border:1px solid rgba(255,255,255,.4);border-radius:50%;transform:translate(-50%,-50%);transition:width .4s var(--ease-out),height .4s var(--ease-out)}
.cursor__text{position:absolute;transform:translate(-50%,-50%);font-size:10px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;opacity:0;transition:opacity .3s}
body.cursor--link .cursor__ring{width:70px;height:70px;border-color:var(--accent)}
body.cursor--link .cursor__dot{width:4px;height:4px}
body.cursor--view .cursor__ring{width:90px;height:90px;background:rgba(255,255,255,.06)}
body.cursor--view .cursor__text{opacity:1}

@media(max-width:768px){
  .cursor{display:none}
  body,a,button,input,textarea,select{cursor:auto}
}

/* ============================================ */
/* PRELOADER                                    */
/* ============================================ */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column}
.preloader__counter{position:absolute;top:40px;right:var(--pad);font-family:var(--serif);font-size:clamp(14px,1.5vw,18px);font-weight:300;color:var(--text-dim)}
.preloader__name{text-align:center}
.preloader__name-line{overflow:hidden}
.preloader__name-line span{display:block;font-family:var(--serif);font-size:clamp(40px,9vw,100px);font-weight:300;letter-spacing:.05em;transform:translateY(110%);opacity:0}
.preloader__bar{width:120px;height:1px;background:var(--border);margin-top:32px;overflow:hidden;opacity:0}
.preloader__bar-inner{width:0;height:100%;background:var(--accent)}

/* ============================================ */
/* NAVIGATION                                   */
/* ============================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:20px var(--pad);mix-blend-mode:difference;opacity:0;transform:translateY(-20px)}
.nav__logo{font-family:var(--serif);font-size:22px;font-weight:400;letter-spacing:.08em}
.nav__logo span{font-size:12px;letter-spacing:.2em;margin-left:4px;opacity:.5}
.nav__center{display:flex;gap:36px}
.nav__link{font-size:12px;font-weight:300;letter-spacing:.08em;text-transform:uppercase;position:relative;padding:4px 0}
.nav__link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--text);transition:width .5s var(--ease-out)}
.nav__link:hover::after{width:100%}
.nav__link--accent{color:var(--accent)}
.nav__link--accent::after{background:var(--accent)}
.nav__cta{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;padding:10px 20px;border:1px solid rgba(255,255,255,.2);border-radius:100px;transition:background .4s,border-color .4s}
.nav__cta:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}
.nav__cta svg{transition:transform .4s var(--ease-out)}
.nav__cta:hover svg{transform:translate(2px,-2px)}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px;z-index:101}
.nav__burger span{display:block;width:24px;height:1px;background:var(--text);transition:transform .4s var(--ease-out),opacity .3s}
.nav__burger.active span:first-child{transform:rotate(45deg) translate(2px,2px)}
.nav__burger.active span:last-child{transform:rotate(-45deg) translate(2px,-2px)}

/* Mobile Nav */
.mobile-nav{position:fixed;inset:0;z-index:99;pointer-events:none}
.mobile-nav.active{pointer-events:all}
.mobile-nav__bg{position:absolute;inset:0;background:rgba(12,10,8,.96);backdrop-filter:blur(20px);opacity:0;transition:opacity .5s var(--ease-out)}
.mobile-nav.active .mobile-nav__bg{opacity:1}
.mobile-nav__content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px}
.mobile-nav__link{font-family:var(--serif);font-size:clamp(28px,7vw,48px);font-weight:300;letter-spacing:.03em;transform:translateY(30px);opacity:0;transition:color .3s}
.mobile-nav__link:hover{color:var(--accent)}
.mobile-nav.active .mobile-nav__link{transform:translateY(0);opacity:1}
.mobile-nav__footer{display:flex;gap:20px;margin-top:24px;opacity:0}
.mobile-nav.active .mobile-nav__footer{opacity:1;transition:opacity .5s .4s}
.mobile-nav__footer a{font-size:13px;letter-spacing:.15em;color:var(--text-dim);transition:color .3s}
.mobile-nav__footer a:hover{color:var(--accent)}

@media(max-width:900px){
  .nav__center,.nav__cta{display:none}
  .nav__burger{display:flex}
}

/* ============================================ */
/* HERO                                         */
/* ============================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding:0 var(--pad)}
.hero__bg{position:absolute;inset:0;overflow:hidden}
.hero__orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.3;will-change:transform}
.hero__orb--1{width:600px;height:600px;background:radial-gradient(circle,var(--accent) 0%,transparent 70%);top:-15%;right:-8%}
.hero__orb--2{width:450px;height:450px;background:radial-gradient(circle,var(--accent-2) 0%,transparent 70%);bottom:-10%;left:-5%}
.hero__orb--3{width:350px;height:350px;background:radial-gradient(circle,var(--accent-3) 0%,transparent 70%);top:50%;left:35%;opacity:.15}
.hero__grain{position:absolute;inset:-50%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");background-repeat:repeat;pointer-events:none}

.hero__content{position:relative;z-index:2;width:100%;max-width:var(--max);margin:0 auto}
.hero__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:clamp(24px,4vh,48px);opacity:0}
.hero__label{font-size:clamp(10px,1vw,12px);font-weight:300;letter-spacing:.25em;text-transform:uppercase;color:var(--text-dim)}

.hero__name{margin-bottom:clamp(24px,4vh,48px)}
.hero__name-row{overflow:hidden}
.hero__name-mask{overflow:hidden;display:inline-block}
.hero__name-text{display:block;font-family:var(--serif);font-size:clamp(60px,13vw,180px);font-weight:300;line-height:.92;letter-spacing:-.02em;transform:translateY(110%)}
.hero__name-text--stroke{-webkit-text-stroke:1.5px var(--text);color:transparent;font-size:clamp(70px,15vw,210px)}
.hero__name-row--indent{padding-left:clamp(40px,8vw,140px)}

.hero__bottom{display:flex;justify-content:space-between;align-items:flex-end}
.hero__tags{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hero__tags span{font-size:clamp(11px,1.1vw,14px);font-weight:300;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);opacity:0;transform:translateY(15px)}
.hero__tag-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);opacity:0}

.hero__scroll-hint{display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0}
.hero__scroll-hint span{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim)}
.hero__scroll-line{width:1px;height:50px;background:var(--border);overflow:hidden}
.hero__scroll-fill{width:100%;height:100%;background:var(--accent);transform:translateY(-100%);animation:scrollPulse 2s var(--ease-in-out) infinite}
@keyframes scrollPulse{0%{transform:translateY(-100%)}50%{transform:translateY(0)}100%{transform:translateY(100%)}}

.hero__portrait{position:absolute;right:clamp(60px,10vw,140px);top:50%;transform:translateY(-50%);width:clamp(180px,22vw,340px);height:clamp(260px,32vw,480px);z-index:1;overflow:hidden;border-radius:200px 200px 24px 24px;opacity:0}
.hero__portrait-inner{width:100%;height:100%;position:relative;overflow:hidden}
.hero__portrait-img{width:100%;height:100%;object-fit:cover;object-position:center top}
.hero__portrait-tag{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);font-size:11px;letter-spacing:.15em;color:rgba(255,255,255,.5);white-space:nowrap}

@media(max-width:1024px){.hero__portrait{display:none}}

/* ============================================ */
/* TICKER / MARQUEE                             */
/* ============================================ */
.ticker{padding:24px 0;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative}
.ticker__track{display:flex;white-space:nowrap;will-change:transform}
.ticker__track span{font-family:var(--serif);font-size:clamp(16px,2.5vw,30px);font-weight:300;letter-spacing:.08em;padding:0 20px;color:var(--text-dim);flex-shrink:0}
.ticker__dot{font-size:clamp(8px,1vw,14px);color:var(--accent);display:flex;align-items:center;padding:0 8px;flex-shrink:0}

/* ============================================ */
/* SHARED                                       */
/* ============================================ */
.label{display:inline-block;font-size:clamp(10px,.9vw,12px);font-weight:300;letter-spacing:.2em;color:var(--text-dim);margin-bottom:24px;text-transform:uppercase}
.label--light{color:var(--accent-3)}
.lw{overflow:hidden}
.lw span{display:inline-block}

/* ============================================ */
/* ABOUT                                        */
/* ============================================ */
.about{position:relative;padding:var(--section) var(--pad);overflow:hidden}
.about__grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,6vw,100px);align-items:center}
.about__col--img{position:relative}
.about__img-wrap{width:100%;aspect-ratio:3/4;overflow:hidden;border-radius:16px;position:relative}
.about__img-mask{width:100%;height:100%;overflow:hidden}
.about__img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.1);transition:transform 1.2s var(--ease-out)}
.about__img-wrap:hover .about__img{transform:scale(1.02)}
.about__badge{position:absolute;bottom:-16px;right:-16px;background:var(--surface);border:1px solid var(--border);padding:14px 22px;border-radius:100px;font-size:11px;letter-spacing:.12em;color:var(--accent);white-space:nowrap}

.about__heading{font-family:var(--serif);font-size:clamp(32px,4.5vw,64px);font-weight:300;line-height:1.1;margin-bottom:28px}
.about__body{font-size:clamp(14px,1.1vw,16px);font-weight:300;line-height:1.8;color:var(--text-dim);margin-bottom:40px}
.about__body p+p{margin-top:14px}
.about__body strong{color:var(--text);font-weight:500}

.about__numbers{display:flex;gap:clamp(24px,3vw,48px)}
.number-block{}
.number-block__val{font-family:var(--serif);font-size:clamp(32px,3.5vw,52px);font-weight:300;color:var(--accent);line-height:1}
.number-block__plus{font-family:var(--serif);font-size:clamp(20px,2vw,32px);color:var(--accent-2)}
.number-block__label{display:block;font-size:10px;font-weight:300;letter-spacing:.1em;color:var(--text-dim);margin-top:6px;text-transform:uppercase}

.about__deco{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none}
.about__deco--1{width:300px;height:300px;background:var(--accent);top:5%;right:-8%;opacity:.08}
.about__deco--2{width:200px;height:200px;background:var(--accent-2);bottom:8%;left:-4%;opacity:.08}

@media(max-width:768px){
  .about__grid{grid-template-columns:1fr}
  .about__col--img{max-width:360px;margin:0 auto}
  .about__numbers{flex-wrap:wrap}
}

/* ============================================ */
/* THE GLOW EXPERIENCE                          */
/* ============================================ */
.glow{position:relative;padding:var(--section) var(--pad);overflow:hidden;min-height:100vh;display:flex;align-items:center;justify-content:center}
.glow__bg{position:absolute;inset:0}
.glow__gradient{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 40%,#2a1f14 0%,#1a1208 40%,var(--bg) 80%)}
.glow__grain{position:absolute;inset:-50%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");background-repeat:repeat;pointer-events:none}

.glow__content{position:relative;z-index:1;text-align:center;max-width:700px}
.glow__title{margin-bottom:40px}
.glow__the{font-family:var(--serif);font-size:clamp(20px,3vw,36px);font-weight:300;font-style:italic;color:var(--accent-3);letter-spacing:.1em}
.glow__word{font-family:var(--serif);font-size:clamp(60px,14vw,160px);font-weight:300;letter-spacing:.05em;background:linear-gradient(135deg,var(--accent-3),var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:.9}
.glow__exp{font-family:var(--serif);font-size:clamp(18px,2.5vw,32px);font-weight:300;font-style:italic;letter-spacing:.2em;color:var(--text-dim)}

.glow__details{display:flex;justify-content:center;gap:clamp(24px,4vw,56px);margin-bottom:32px;flex-wrap:wrap}
.glow__detail{text-align:center}
.glow__detail-label{display:block;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);margin-bottom:4px}
.glow__detail-value{font-family:var(--serif);font-size:clamp(16px,1.5vw,20px);font-weight:400;color:var(--accent-3)}

.glow__desc{font-size:clamp(14px,1.2vw,16px);font-weight:300;line-height:1.8;color:var(--text-dim);margin-bottom:40px;max-width:520px;margin-left:auto;margin-right:auto}

.btn--glow{background:linear-gradient(135deg,var(--accent-3),var(--accent));color:var(--bg);padding:18px 40px;font-size:15px;font-weight:500}
.btn--glow:hover{box-shadow:0 0 40px rgba(200,169,125,.25)}

.glow__limited{display:inline-flex;align-items:center;gap:10px;margin-top:24px;font-size:12px;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--accent)}
.glow__pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.5)}}

/* ============================================ */
/* PORTFOLIO (Horizontal Scroll)                */
/* ============================================ */
.portfolio{position:relative;padding:var(--section) 0;background:var(--bg-alt)}
.portfolio__header{padding:0 var(--pad);max-width:var(--max);margin:0 auto clamp(40px,5vw,64px)}
.portfolio__heading{font-family:var(--serif);font-size:clamp(48px,8vw,120px);font-weight:300;line-height:.95}
.portfolio__sub{font-size:13px;font-weight:300;color:var(--text-dim);letter-spacing:.1em;margin-top:12px}

.portfolio__wrap{overflow:hidden;position:relative}
.portfolio__track{display:flex;gap:clamp(16px,2vw,28px);padding:0 var(--pad);will-change:transform}

.portfolio__card{flex-shrink:0;width:clamp(280px,30vw,400px);position:relative;overflow:hidden;border-radius:12px}
.portfolio__card-img{width:100%;aspect-ratio:3/4;overflow:hidden;position:relative}
.portfolio__card--tall .portfolio__card-img{aspect-ratio:2/3}
.portfolio__card-gradient{position:absolute;inset:0;background:var(--g);transform:scale(1.08);transition:transform .8s var(--ease-out)}
.portfolio__card:hover .portfolio__card-gradient{transform:scale(1)}
.portfolio__card-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.08);transition:transform .8s var(--ease-out)}
.portfolio__card:hover .portfolio__card-photo{transform:scale(1)}

.portfolio__card-info{position:absolute;bottom:0;left:0;right:0;padding:clamp(16px,2vw,28px);background:linear-gradient(180deg,transparent 0%,rgba(12,10,8,.85) 100%);transform:translateY(8px);opacity:0;transition:all .5s var(--ease-out)}
.portfolio__card:hover .portfolio__card-info{transform:translateY(0);opacity:1}
.portfolio__card-cat{font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:6px;display:block}
.portfolio__card-info h3{font-family:var(--serif);font-size:clamp(18px,1.8vw,24px);font-weight:400}

.portfolio__footer{padding:clamp(32px,4vw,56px) var(--pad) 0;max-width:var(--max);margin:0 auto;text-align:center}

/* ============================================ */
/* SERVICES                                     */
/* ============================================ */
.services{padding:var(--section) var(--pad)}
.services__header{max-width:var(--max);margin:0 auto clamp(40px,5vw,64px)}
.services__heading{font-family:var(--serif);font-size:clamp(36px,5vw,72px);font-weight:300;line-height:1.1}

.services__list{max-width:var(--max);margin:0 auto}
.svc{display:grid;grid-template-columns:60px 1fr auto auto;gap:clamp(16px,2vw,32px);align-items:start;padding:clamp(24px,3vw,40px) 0;border-bottom:1px solid var(--border);position:relative;transition:border-color .5s}
.svc:first-child{border-top:1px solid var(--border)}
.svc:hover{border-color:var(--border-h)}

.svc__num{font-family:var(--serif);font-size:clamp(14px,1.2vw,18px);font-weight:300;color:var(--text-dim);padding-top:4px}
.svc__badge{position:absolute;top:clamp(24px,3vw,40px);right:60px;font-size:9px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold);padding:3px 10px;border-radius:100px}
.svc__body{}
.svc__title{font-family:var(--serif);font-size:clamp(22px,2.5vw,36px);font-weight:400;margin-bottom:8px;transition:color .4s}
.svc:hover .svc__title{color:var(--accent)}
.svc__desc{font-size:clamp(13px,1vw,15px);font-weight:300;line-height:1.7;color:var(--text-dim);max-width:480px}

.svc__tags{display:flex;flex-wrap:wrap;gap:6px;align-self:center}
.svc__tags span{font-size:10px;font-weight:400;letter-spacing:.05em;color:var(--text-dim);background:var(--surface);padding:5px 12px;border-radius:100px;border:1px solid var(--border);transition:border-color .3s,color .3s}
.svc:hover .svc__tags span{border-color:var(--border-h);color:var(--text)}

.svc__arrow{align-self:center;color:var(--text-dim);transition:color .4s,transform .4s var(--ease-out)}
.svc:hover .svc__arrow{color:var(--accent);transform:translate(4px,-4px)}

.svc--soon{opacity:.6;transition:opacity .5s}
.svc--soon:hover{opacity:1}

@media(max-width:768px){
  .svc{grid-template-columns:1fr;gap:12px}
  .svc__num{font-size:12px}
  .svc__tags{margin-top:8px}
  .svc__arrow{display:none}
  .svc__badge{position:static;display:inline-block;margin-bottom:8px}
}

/* ============================================ */
/* COLLABORATION                                */
/* ============================================ */
.collab{padding:var(--section) var(--pad);background:var(--bg-warm);position:relative}
.collab__inner{max-width:800px;margin:0 auto;text-align:center}
.collab__heading{font-family:var(--serif);font-size:clamp(36px,5.5vw,80px);font-weight:300;line-height:1.05;margin-bottom:28px}
.collab__text{font-size:clamp(14px,1.2vw,16px);font-weight:300;line-height:1.8;color:var(--text-dim);margin-bottom:40px}

.collab__brands{margin-bottom:40px}
.collab__brand-tag{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--text-dim);display:block;margin-bottom:12px}
.collab__brand-list{display:flex;justify-content:center;gap:24px;flex-wrap:wrap}
.collab__brand-list span{font-family:var(--serif);font-size:clamp(18px,2vw,24px);font-weight:300;color:var(--accent-3)}

.collab__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
.collab__stat{text-align:center;padding:20px;border:1px solid var(--border);border-radius:12px;transition:border-color .4s}
.collab__stat:hover{border-color:var(--border-h)}
.collab__stat-icon{display:block;width:28px;height:28px;margin:0 auto 10px;color:var(--accent)}
.collab__stat-icon svg{width:100%;height:100%}
.collab__stat-label{font-size:12px;font-weight:300;letter-spacing:.05em;color:var(--text-dim)}

@media(max-width:600px){.collab__grid{grid-template-columns:1fr}}

/* ============================================ */
/* BUTTONS                                      */
/* ============================================ */
.btn{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;padding:14px 28px;border-radius:100px;border:none;position:relative;overflow:hidden;transition:all .4s var(--ease-out);background:none}
.btn span{position:relative;z-index:1}
.btn svg{position:relative;z-index:1;transition:transform .4s var(--ease-out)}
.btn:hover svg{transform:translate(3px,-3px)}

.btn--primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--bg)}
.btn--primary:hover{box-shadow:0 8px 32px rgba(200,169,125,.2)}
.btn--outline{border:1px solid var(--border-h);color:var(--text)}
.btn--outline:hover{background:rgba(200,169,125,.06);border-color:var(--accent)}
.btn--lg{padding:18px 40px;font-size:14px}
.btn--full{width:100%;justify-content:center}

/* ============================================ */
/* CONTACT                                      */
/* ============================================ */
.contact{padding:var(--section) var(--pad);background:var(--bg-alt)}
.contact__grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,8vw,120px)}
.contact__heading{font-family:var(--serif);font-size:clamp(48px,7vw,100px);font-weight:300;line-height:1;margin-bottom:20px}
.contact__intro{font-size:clamp(14px,1.2vw,16px);font-weight:300;line-height:1.7;color:var(--text-dim);margin-bottom:40px}

.contact__links{display:flex;flex-direction:column;gap:12px}
.contact__link{display:flex;align-items:center;gap:14px;padding:14px 18px;border:1px solid var(--border);border-radius:12px;transition:border-color .4s,background .4s}
.contact__link:hover{border-color:var(--border-h);background:rgba(200,169,125,.03)}
.contact__link-icon{width:22px;height:22px;color:var(--accent);flex-shrink:0}
.contact__link-icon svg{width:100%;height:100%}
.contact__link-label{font-size:13px;font-weight:500;display:block}
.contact__link-value{font-size:12px;font-weight:300;color:var(--text-dim);display:block;margin-top:2px}

/* Form */
.form{display:flex;flex-direction:column;gap:28px}
.form__group{position:relative}
.form__group input,.form__group textarea,.form__group select{width:100%;background:transparent;border:none;border-bottom:1px solid var(--border);padding:14px 0;font-size:14px;font-weight:300;color:var(--text);outline:none;transition:border-color .4s;border-radius:0;-webkit-appearance:none}
.form__group input:focus,.form__group textarea:focus,.form__group select:focus{border-color:var(--accent)}
.form__group label{position:absolute;top:14px;left:0;font-size:13px;font-weight:300;color:var(--text-dim);pointer-events:none;transition:all .3s var(--ease-out)}
.form__group input:focus~label,.form__group input:not(:placeholder-shown)~label,
.form__group textarea:focus~label,.form__group textarea:not(:placeholder-shown)~label{top:-10px;font-size:10px;color:var(--accent);letter-spacing:.1em;text-transform:uppercase}
.form__group select{appearance:none}
.form__group select option{background:var(--bg);color:var(--text)}
.form__group textarea{resize:vertical;min-height:80px}

@media(max-width:768px){.contact__grid{grid-template-columns:1fr}}

/* ============================================ */
/* FOOTER                                       */
/* ============================================ */
.footer{position:relative;padding:32px var(--pad);border-top:1px solid var(--border)}
.footer__inner{max-width:var(--max);margin:0 auto}
.footer__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.footer__logo{font-family:var(--serif);font-size:20px;font-weight:300;letter-spacing:.1em}
.footer__social{display:flex;gap:24px}
.footer__social a{font-size:12px;font-weight:300;color:var(--text-dim);letter-spacing:.05em;transition:color .3s}
.footer__social a:hover{color:var(--accent)}
.footer__bottom{display:flex;justify-content:space-between;padding-top:20px;border-top:1px solid var(--border);font-size:11px;font-weight:300;color:var(--text-dim)}
.footer__up{position:absolute;right:var(--pad);top:-20px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:50%;color:var(--text);transition:border-color .4s,transform .4s var(--ease-out)}
.footer__up:hover{border-color:var(--accent);transform:translateY(-4px)}

@media(max-width:600px){
  .footer__top,.footer__bottom{flex-direction:column;gap:12px;align-items:flex-start}
}
