/*

* Theme Name: GF-USA

* Theme URI: https://www.guinotfranchisesusa.com/

* Version: 1.0

* Author: aaybeepk

* Author URI: rentable.pk

* Description: Guinot Franchises USA official website

*

*/





*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

a { color: inherit; text-decoration: none; }

a:hover { text-decoration: none; }



:root {

  --burgundy:    #7B1C3E;

  --burgundy-2:  #9B2450;

  --burgundy-3:  #C41850;

  --burgundy-pale:#F5E8EE;

  --gold:        #B89A5A;

  --gold-light:  #D4B878;

  --gold-pale:   #F7F0E2;

  --cream:       #FDFAF6;

  --ivory:       #F5F0EA;

  --linen:       #EDE5D8;

  --charcoal:    #1E1410;

  --brown:       #3D2B1F;

  --grey:        #7A6E68;

  --grey-light:  #B0A8A2;

  --white:       #FFFFFF;

  --wire:        rgba(184,154,90,0.18);

  --wire-dark:   rgba(123,28,62,0.12);

  --serif: 'Playfair Display', Georgia, serif;

  --sans:  'DM Sans', sans-serif;

}



html { scroll-behavior: smooth; }

body {

  font-family: var(--sans);

  background: var(--cream);

  color: var(--charcoal);

  font-size: 15px;

  line-height: 1.75;

  overflow-x: hidden;

}



.container { max-width: 1240px; margin: 0 auto; padding: 0 48px; }

@media(max-width:768px){ .container{ padding:0 22px; } }



.label { font-size: 9.5px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase; color: var(--burgundy-3); display: block; }

.label-gold { font-size: 9.5px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase; color: var(--gold); display: block; }



.display-title { font-family: var(--serif); font-size: clamp(32px, 4.5vw, 60px); font-weight: 400; line-height: 1.1; color: var(--charcoal); }

.display-title em { font-style: italic; color: var(--burgundy); }

.display-title-white { color: var(--white); }

.display-title-white em { color: var(--gold-light); }



.line-burg { width: 44px; height: 2px; background: var(--burgundy-3); display: block; margin: 18px 0; }

.line-gold  { width: 44px; height: 2px; background: var(--gold); display: block; margin: 18px 0; }



.body-text { font-size: 14.5px; font-weight: 300; color: var(--grey); line-height: 1.85; margin-bottom: 16px; }

.body-text strong { color: var(--brown); font-weight: 500; }



.btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--sans); font-size: 10px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; text-decoration: none; padding: 14px 30px; transition: all 0.3s ease; cursor: pointer; position: relative; overflow: hidden; border: none; }

.btn-burg { background: var(--burgundy); color: var(--white); border: 1px solid var(--burgundy); }

.btn-burg:hover { background: var(--burgundy-2); }

.btn-gold { background: var(--gold); color: var(--white); border: 1px solid var(--gold); }

.btn-gold:hover { background: var(--gold-light); }

.btn-outline-burg { background: transparent; color: var(--burgundy); border: 1px solid var(--burgundy); }

.btn-outline-burg:hover { background: var(--burgundy); color: var(--white); }

.btn-outline-light { background: transparent; color: var(--white); border: 1px solid rgba(255,255,255,0.55); }

.btn-outline-light:hover { background: var(--white); color: var(--burgundy); }

.btn-arrow::after { content: ' →'; font-size: 13px; }



/* TICKER */

.ticker { background: var(--burgundy); padding: 9px 0; overflow: hidden; white-space: nowrap; }

.ticker-inner { display: inline-flex; animation: ticker 30s linear infinite; }

.ticker-item { font-size: 10px; font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase; color: rgba(255,255,255,0.92); padding: 0 32px; display: flex; align-items: center; gap: 32px; }

.ticker-item::after { content: '◆'; font-size: 5px; opacity: 0.55; }

@keyframes ticker { 0%{ transform:translateX(0) } 100%{ transform:translateX(-50%) } }



/* HEADER */

header { position: sticky; top: 0; z-index: 200; background: rgba(253,250,246,0.96); backdrop-filter: blur(18px); border-bottom: 1px solid var(--wire); transition: box-shadow 0.3s; }

header.scrolled { box-shadow: 0 4px 32px rgba(123,28,62,0.08); }

nav { display:flex; align-items:center; justify-content:space-between; padding:0 48px; height:76px; }

@media(max-width:768px){ nav{ padding:0 22px; height:64px; } }



.nav-logo { text-decoration: none; display:flex; flex-direction:column; }

.nav-logo-main { font-family: var(--serif); font-size: 22px; font-weight: 500; letter-spacing: 4px; text-transform: uppercase; color: var(--burgundy); line-height: 1; }

.nav-logo-sub { font-size: 7.5px; font-weight: 600; letter-spacing: 3.5px; text-transform: uppercase; color: var(--grey); margin-top: 3px; }



.nav-links { display:flex; gap:36px; list-style:none; }

@media(max-width:960px){ .nav-links{ display:none; } }

.nav-links a { font-size: 9.5px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--brown); text-decoration: none; transition: color 0.2s; padding-bottom: 3px; position: relative; }

.nav-links a::after { content:''; position:absolute; bottom:0; left:0; width:0; height:1px; background:var(--burgundy-3); transition: width 0.3s; }

.nav-links a:hover { color: var(--burgundy); text-decoration: none; }

.nav-links a:hover::after { width:100%; }



.nav-right { display:flex; align-items:center; gap:16px; }

.nav-phone { font-size: 12px; font-weight: 500; color: var(--burgundy); text-decoration: none; letter-spacing: 0.5px; transition: color 0.2s; }

.nav-phone:hover { color: var(--burgundy-3); }

@media(max-width:768px){ .nav-phone{ display:none; } }



.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:4px; }

.hamburger span { display:block; width:22px; height:1.5px; background:var(--charcoal); transition:all .3s; }

@media(max-width:960px){ .hamburger{ display:flex; } }



/* MOBILE MENU */

.mobile-menu { display:none; position:fixed; inset:0; background:var(--cream); z-index:999; flex-direction:column; padding:100px 40px 40px; overflow-y:auto; }

.mobile-menu.open { display:flex; }

.mobile-menu a { font-family:var(--serif); font-size:clamp(26px,6vw,42px); font-weight:400; color:var(--charcoal); text-decoration:none; padding:14px 0; border-bottom:1px solid var(--wire); transition:color 0.2s; }

.mobile-menu a:hover { color:var(--burgundy); }

.mobile-close { position:absolute; top:22px; right:26px; font-size:28px; cursor:pointer; color:var(--grey); background:none; border:none; font-family:var(--sans); }

.mobile-cta { margin-top:36px; }



/* HERO */

.hero { position: relative; min-height: 95vh; display: grid; grid-template-columns: 1fr 1fr; overflow: hidden; background: var(--cream); }

@media(max-width:900px){ .hero{ grid-template-columns:1fr; min-height:auto; } }



.hero-left { position: relative; z-index: 2; display: flex; flex-direction: column; justify-content: center; padding: 100px 56px 80px 48px; background: var(--cream); }

@media(max-width:768px){ .hero-left{ padding:70px 22px 60px; } }

.hero-left::before { content: 'G'; font-family: var(--serif); font-size: 520px; font-weight: 700; color: rgba(123,28,62,0.04); position: absolute; top: -80px; left: -60px; line-height: 1; pointer-events: none; z-index: 0; user-select:none; }



.hero-eyebrow { display:flex; align-items:center; gap:14px; margin-bottom:28px; position:relative; z-index:1; }

.hero-eyebrow::before { content:''; width:28px; height:1px; background:var(--burgundy-3); flex-shrink:0; }

.hero-eyebrow span { font-size:9.5px; font-weight:600; letter-spacing:4px; text-transform:uppercase; color:var(--grey); }



.hero-heading { font-family: var(--serif); font-size: clamp(46px,6vw,88px); font-weight: 400; line-height: 1.0; color: var(--charcoal); position: relative; z-index: 1; margin-bottom: 8px; }

.hero-heading .ital { font-style:italic; color:var(--burgundy); }

.hero-heading .gold-line { color:var(--gold); display:flex; align-items:center; gap:16px; }

.hero-heading .gold-line::before { content:''; width:36px; height:2px; background:var(--gold); flex-shrink:0; }



.hero-sub { font-size: 15px; font-weight: 300; color: var(--grey); max-width: 440px; line-height: 1.85; margin: 26px 0 36px; position: relative; z-index: 1; }

.hero-sub strong { color: var(--brown); font-weight: 500; }

.hero-actions { display:flex; gap:14px; flex-wrap:wrap; position:relative; z-index:1; }



.hero-badge { position: absolute; bottom: 48px; left: 48px; z-index: 3; background: var(--gold-pale); border: 1px solid var(--wire); border-left: 3px solid var(--gold); padding: 16px 22px; display: flex; flex-direction: column; gap: 3px; }

@media(max-width:900px){ .hero-badge{ display:none; } }

.hero-badge-label { font-size:8px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--gold); }

.hero-badge-text  { font-family:var(--serif); font-size:17px; font-weight:400; color:var(--brown); font-style:italic; }

.hero-badge-sub   { font-size:10px; color:var(--grey); }



.hero-right { position: relative; overflow: hidden; background: linear-gradient(135deg, var(--burgundy-pale) 0%, var(--linen) 40%, var(--gold-pale) 100%); display: flex; align-items: center; justify-content: center; }

@media(max-width:900px){ .hero-right{ min-height:420px; } }



.hero-product-wrap { position: relative; width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; padding: 60px 40px; }



.hero-ring { position: absolute; border-radius: 50%; border: 1px solid rgba(184,154,90,0.2); }

.hero-ring-1 { width:480px; height:480px; top:50%; left:50%; transform:translate(-50%,-50%); }

.hero-ring-2 { width:360px; height:360px; top:50%; left:50%; transform:translate(-50%,-50%); border-color:rgba(123,28,62,0.12); }

.hero-ring-3 { width:240px; height:240px; top:50%; left:50%; transform:translate(-50%,-50%); border-color:rgba(184,154,90,0.25); }



.guinot-logo-hero { position: relative; z-index: 2; text-align: center; }

.guinot-wordmark { font-family: var(--serif); font-size: clamp(52px, 7vw, 96px); font-weight: 400; letter-spacing: 12px; color: var(--burgundy); text-transform: uppercase; display: block; line-height: 1; }

.guinot-wordmark-sub { font-size: 11px; font-weight: 600; letter-spacing: 8px; text-transform: uppercase; color: var(--gold); display: block; margin-top: 10px; }

.guinot-tagline { font-family: var(--serif); font-size: 14px; font-style: italic; color: var(--burgundy); margin-top: 28px; opacity: 0.8; display: block; }



.product-pill { position: absolute; z-index: 3; background: var(--white); border: 1px solid var(--wire); border-left: 3px solid var(--burgundy-3); padding: 10px 16px; box-shadow: 0 4px 20px rgba(123,28,62,0.08); }

.pp-1 { top: 14%; left: 6%; animation: floatA 5s ease-in-out infinite; }

.pp-2 { top: 22%; right: 6%; animation: floatB 6s ease-in-out infinite; }

.pp-3 { bottom: 22%; left: 4%; animation: floatA 7s ease-in-out infinite .5s; }

.pp-4 { bottom: 14%; right: 5%; animation: floatB 5.5s ease-in-out infinite .3s; }

@keyframes floatA { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

@keyframes floatB { 0%,100%{transform:translateY(0)} 50%{transform:translateY(8px)} }

.product-pill-label { font-size:8px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--burgundy-3); }

.product-pill-name  { font-size:11px; font-weight:500; color:var(--charcoal); margin-top:2px; }



.hero-contact-card { position: absolute; bottom: 40px; right: 36px; z-index: 5; background: rgba(253,250,246,0.95); backdrop-filter: blur(12px); border: 1px solid var(--wire); border-top: 3px solid var(--burgundy-3); padding: 22px 24px; min-width: 230px; box-shadow: 0 8px 40px rgba(123,28,62,0.12); }

@media(max-width:1100px){ .hero-contact-card{ display:none; } }

.hcc-name  { font-family:var(--serif); font-size:15px; font-weight:500; color:var(--charcoal); margin-bottom:2px; }

.hcc-role  { font-size:8px; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:var(--grey); margin-bottom:14px; padding-bottom:12px; border-bottom:1px solid var(--wire); }

.hcc-item  { display:flex; align-items:center; gap:9px; font-size:12px; color:var(--brown); text-decoration:none; margin-bottom:8px; transition:color 0.2s; }

.hcc-item:hover { color:var(--burgundy); }

.hcc-item svg { width:12px; height:12px; flex-shrink:0; color:var(--burgundy-3); }



.hero-scroll { position: absolute; bottom: 36px; left: 50%; transform: translateX(-50%); z-index: 4; display:flex; flex-direction:column; align-items:center; gap:8px; }

.scroll-bar { width:1px; height:52px; background:var(--wire-dark); position:relative; overflow:hidden; }

.scroll-bar::after { content:''; position:absolute; top:-100%; width:100%; height:50%; background:var(--burgundy-3); animation: scrollDown 2.2s ease-in-out infinite; }

@keyframes scrollDown { 0%{top:-50%} 100%{top:150%} }

.hero-scroll span { font-size:8px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--grey); }



.h-a1{opacity:0;animation:hIn .9s .2s cubic-bezier(.16,1,.3,1) forwards}

.h-a2{opacity:0;animation:hIn .9s .35s cubic-bezier(.16,1,.3,1) forwards}

.h-a3{opacity:0;animation:hIn .9s .5s cubic-bezier(.16,1,.3,1) forwards}

.h-a4{opacity:0;animation:hIn .9s .65s cubic-bezier(.16,1,.3,1) forwards}

.h-a5{opacity:0;animation:hIn .9s .8s cubic-bezier(.16,1,.3,1) forwards}

@keyframes hIn{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}



/* STATS */

.stats-band { background:var(--burgundy); border-top:1px solid rgba(255,255,255,0.1); }

.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); }

@media(max-width:640px){ .stats-grid{ grid-template-columns:repeat(2,1fr); } }

.stat-cell { padding:34px 24px; text-align:center; border-right:1px solid rgba(255,255,255,0.12); transition:background .3s; }

.stat-cell:last-child{ border-right:none; }

.stat-cell:hover{ background:rgba(255,255,255,0.06); }

.stat-n { font-family:var(--serif); font-size:42px; font-weight:400; color:var(--gold-light); line-height:1; display:block; }

.stat-label { font-size:9px; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:rgba(255,255,255,0.6); margin-top:7px; display:block; }



.section { padding:110px 0; }

.section-sm { padding:72px 0; }



/* ABOUT */

.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:90px; align-items:center; }

@media(max-width:860px){ .about-grid{ grid-template-columns:1fr; gap:52px; } }

.about-img-wrap { position:relative; }

.about-img-main { width:100%; aspect-ratio:3/4; object-fit:cover; display:block; }

.about-img-accent { position:absolute; width:52%; aspect-ratio:1; object-fit:cover; bottom:-32px; right:-32px; border:7px solid var(--cream); }

@media(max-width:768px){ .about-img-accent{ display:none; } }

.about-tag { position:absolute; top:-1px; left:-1px; background:var(--burgundy); padding:14px 18px; display:flex; flex-direction:column; align-items:center; }

.about-tag span:first-child { font-family:var(--serif); font-size:28px; font-weight:400; color:var(--white); line-height:1; }

.about-tag span:last-child  { font-size:8px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.7); }

.about-features { margin-top:36px; }

.about-feature { display:flex; gap:18px; align-items:flex-start; padding:17px 0; border-bottom:1px solid var(--wire); }

.about-feature:first-child { border-top:1px solid var(--wire); }

.about-feature-num { font-family:var(--serif); font-size:13px; font-style:italic; color:var(--burgundy-3); flex-shrink:0; width:20px; padding-top:1px; }

.about-feature-title { font-size:10.5px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--charcoal); margin-bottom:3px; }

.about-feature-text { font-size:13px; color:var(--grey); line-height:1.6; }



/* ADDRESS BAND */

.address-band { background: var(--ivory); border-top:1px solid var(--wire); border-bottom:1px solid var(--wire); padding: 36px 0; }

.address-inner { display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }

.address-left { display:flex; align-items:center; gap:20px; }

.address-flag { font-size:32px; line-height:1; }

.address-co { font-size:10px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--burgundy); margin-bottom:4px; }

.address-street { font-size:14px; color:var(--brown); font-weight:400; }

.address-city { font-size:13px; color:var(--grey); margin-top:2px; }

.address-right { display:flex; gap:28px; flex-wrap:wrap; }

.addr-contact { display:flex; flex-direction:column; gap:3px; }

.addr-contact-label { font-size:8px; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:var(--grey-light); }

.addr-contact-value { font-size:13px; font-weight:500; color:var(--brown); text-decoration:none; }

.addr-contact-value:hover { color:var(--burgundy); }



/* TEAM BAND */

.team-band { background:var(--burgundy); }

.team-inner { display:grid; grid-template-columns:auto 1fr; align-items:stretch; }

@media(max-width:860px){ .team-inner{ grid-template-columns:1fr; } }

.team-identity { padding:44px 56px 44px 48px; border-right:1px solid rgba(255,255,255,0.12); display:flex; flex-direction:column; justify-content:center; }

@media(max-width:860px){ .team-identity{ border-right:none; border-bottom:1px solid rgba(255,255,255,0.12); padding:36px 24px; } }

.team-tag  { font-size:8.5px; font-weight:600; letter-spacing:4px; text-transform:uppercase; color:var(--gold-light); margin-bottom:10px; }

.team-name { font-family:var(--serif); font-size:26px; font-weight:400; font-style:italic; color:var(--white); margin-bottom:6px; line-height:1.2; }

.team-role { font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.55); }

.team-contacts { display:grid; grid-template-columns:repeat(4,1fr); }

@media(max-width:900px){ .team-contacts{ grid-template-columns:repeat(2,1fr); } }

@media(max-width:480px){ .team-contacts{ grid-template-columns:1fr; } }

.team-cell { padding:28px 24px; border-right:1px solid rgba(255,255,255,0.1); text-decoration:none; display:flex; flex-direction:column; justify-content:center; gap:5px; transition:background .25s; }

.team-cell:last-child{ border-right:none; }

.team-cell:hover{ background:rgba(255,255,255,0.07); }

.team-cell-label { font-size:8px; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:rgba(255,255,255,0.45); display:flex; align-items:center; gap:7px; }

.team-cell-label svg { width:11px; height:11px; }

.team-cell-value { font-size:13px; color:rgba(255,255,255,0.88); font-weight:400; }

.team-cell:hover .team-cell-value { color:var(--white); }



/* ANTI-AGING */

.antiaging-section { background: linear-gradient(135deg, var(--burgundy) 0%, #5A0E2A 60%, var(--charcoal) 100%); padding: 100px 0; position: relative; overflow: hidden; }

.antiaging-section::before { content:''; position:absolute; top:0; left:0; right:0; bottom:0; background: radial-gradient(ellipse at 70% 50%, rgba(184,154,90,0.12) 0%, transparent 65%); pointer-events:none; }

.antiaging-grid { display:grid; grid-template-columns:1fr 1fr; gap:90px; align-items:center; position:relative; z-index:1; }

@media(max-width:860px){ .antiaging-grid{ grid-template-columns:1fr; gap:52px; } }

.antiaging-text .body-text { color:rgba(255,255,255,0.7); }

.antiaging-text .body-text strong { color:var(--gold-light); }

.antiaging-cards { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

@media(max-width:480px){ .antiaging-cards{ grid-template-columns:1fr; } }

.aa-card { background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); border-top:2px solid var(--gold); padding:24px 20px; transition:background .3s; }

.aa-card:hover { background:rgba(255,255,255,0.1); }

.aa-card-icon { font-size:22px; margin-bottom:12px;  color: #dcb777; }

.aa-card-title { font-family:var(--serif); font-size:16px; font-weight:400; color:var(--white); margin-bottom:8px; line-height:1.25; }

.aa-card-text { font-size:12.5px; color:rgba(255,255,255,0.55); line-height:1.65; }

.aa-stat-row { display:flex; gap:32px; margin-top:36px; flex-wrap:wrap; }

.aa-stat-item { display:flex; flex-direction:column; gap:4px; }

.aa-stat-n { font-family:var(--serif); font-size:36px; font-weight:400; color:var(--gold-light); line-height:1; }

.aa-stat-l { font-size:9px; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:rgba(255,255,255,0.5); }



/* WHY */

.why-section { background:var(--ivory); }

.why-header { display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:end; margin-bottom:64px; }

@media(max-width:768px){ .why-header{ grid-template-columns:1fr; gap:20px; } }

.why-header-right { font-size:14.5px; font-weight:300; color:var(--grey); line-height:1.85; }

.why-grid { display:grid; grid-template-columns:repeat(3,1fr); border:1px solid var(--wire); }

@media(max-width:900px){ .why-grid{ grid-template-columns:1fr 1fr; } }

@media(max-width:560px){ .why-grid{ grid-template-columns:1fr; } }

.why-card { padding:40px 32px; border-right:1px solid var(--wire); border-bottom:1px solid var(--wire); transition:background .3s; position:relative; overflow:hidden; }

.why-card:hover { background:var(--burgundy-pale); }

.why-card:nth-child(3n){ border-right:none; }

.why-card::after { content:''; position:absolute; bottom:0; left:0; height:2px; width:0; background:var(--burgundy-3); transition:width .4s ease; }

.why-card:hover::after{ width:100%; }

.why-card-num { font-size:9px; font-weight:600; letter-spacing:3px; color:var(--burgundy-3); margin-bottom:16px; }

.why-card-title { font-family:var(--serif); font-size:20px; font-weight:400; color:var(--charcoal); margin-bottom:12px; line-height:1.25; }

.why-card-text { font-size:13.5px; font-weight:300; color:var(--grey); line-height:1.75; }



/* OPPORTUNITY */

.opp-section { background:var(--cream); }

.opp-grid { display:grid; grid-template-columns:1fr 1fr; gap:90px; align-items:start; }

@media(max-width:860px){ .opp-grid{ grid-template-columns:1fr; gap:52px; } }

.territory-cards { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:32px 0; }

.t-card { border:1px solid var(--wire); border-top:3px solid var(--gold); padding:22px 20px; background:var(--gold-pale); transition:background .25s, border-color .25s; }

.t-card:hover { background:var(--linen); border-top-color:var(--burgundy-3); }

/*.t-card-icon { font-size:24px; margin-bottom:10px; }*/

.t-card-title { font-size:11px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--charcoal); margin-bottom:6px; }

.t-card-text { font-size:12.5px; color:var(--grey); line-height:1.6; }

.opp-list { list-style:none; margin-top:10px; margin-bottom:28px; }

.opp-list li { display:flex; gap:14px; align-items:flex-start; padding:14px 0; border-bottom:1px solid var(--wire); font-size:13.5px; color:var(--brown); transition:color .2s; }

.opp-list li:first-child{ border-top:1px solid var(--wire); }

.opp-list li:hover { color:var(--charcoal); }

.opp-check { width:18px; height:18px; flex-shrink:0; border:1px solid var(--burgundy-3); border-radius:50%; display:flex; align-items:center; justify-content:center; margin-top:2px; }

.opp-check svg { width:8px; height:8px; }

.opp-img-wrap { position:relative; }

.opp-img-main { width:100%; aspect-ratio:3/4; object-fit:cover; display:block; }

.opp-img-tag { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(to top,rgba(123,28,62,0.92) 0%,transparent 100%); padding:60px 28px 28px; }

.opp-img-tag p { font-family:var(--serif); font-size:19px; font-style:italic; color:var(--white); margin-bottom:5px; }

.opp-img-tag span { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,0.65); }



/* PROCESS */

.process-section { background:var(--linen); }

.process-header { text-align:center; margin-bottom:64px; }

.process-header p { font-size:14px; font-weight:300; color:var(--grey); max-width:500px; margin:16px auto 0; }

.process-steps { display:grid; grid-template-columns:repeat(5,1fr); border:1px solid var(--wire); }

@media(max-width:900px){ .process-steps{ grid-template-columns:1fr 1fr; } }

@media(max-width:540px){ .process-steps{ grid-template-columns:1fr; } }

.process-step { padding:38px 26px; border-right:1px solid var(--wire); position:relative; transition:background .3s; }

.process-step:last-child{ border-right:none; }

.process-step:hover{ background:var(--burgundy-pale); }

.step-num { font-family:var(--serif); font-size:44px; font-weight:400; font-style:italic; color:var(--burgundy-3); opacity:.5; line-height:1; margin-bottom:18px; }

.step-title { font-family:var(--serif); font-size:16px; font-weight:500; color:var(--charcoal); margin-bottom:9px; }

.step-text { font-size:12px; font-weight:300; color:var(--grey); line-height:1.65; }

.step-arrow { position:absolute; top:50%; right:-10px; transform:translateY(-50%); width:18px; height:18px; background:var(--linen); border:1px solid var(--wire); display:flex; align-items:center; justify-content:center; font-size:11px; color:var(--burgundy-3); z-index:1; }

.process-step:last-child .step-arrow{ display:none; }

@media(max-width:900px){ .step-arrow{ display:none; } }



/* BRAND */

.brand-section { background:var(--cream); overflow:hidden; position:relative; }

.brand-watermark { font-family:var(--serif); font-size:200px; font-weight:700; color:rgba(123,28,62,0.035); position:absolute; right:-20px; top:50%; transform:translateY(-50%); white-space:nowrap; pointer-events:none; letter-spacing:10px; user-select:none; }

.brand-grid { display:grid; grid-template-columns:1.1fr 1fr; gap:90px; align-items:center; position:relative; z-index:1; }

@media(max-width:860px){ .brand-grid{ grid-template-columns:1fr; gap:52px; } }

.brand-timeline { margin-top:36px; padding-left:24px; border-left:1px solid var(--wire); }

.tl-item { margin-bottom:28px; position:relative; }

.tl-item::before { content:''; position:absolute; left:-30px; top:8px; width:8px; height:8px; background:var(--cream); border:1.5px solid var(--burgundy-3); border-radius:50%; }

.tl-year { font-size:9px; font-weight:600; letter-spacing:3px; color:var(--burgundy-3); text-transform:uppercase; margin-bottom:4px; }

.tl-text { font-size:13.5px; font-weight:300; color:var(--grey); line-height:1.65; }

.brand-img img { width:100%; aspect-ratio:3/4; object-fit:cover; display:block; }

.brand-img-caption { background:var(--burgundy); padding:20px 24px; display:flex; justify-content:space-between; align-items:center; }

.brand-img-caption p { font-family:var(--serif); font-size:14px; font-style:italic; color:var(--white); }

.brand-img-caption span { font-size:8.5px; letter-spacing:2.5px; text-transform:uppercase; color:rgba(255,255,255,0.55); }



/* TESTIMONIALS */

.testimonials-section { background:var(--ivory); }

.test-header { text-align:center; margin-bottom:64px; }

.test-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }

@media(max-width:860px){ .test-grid{ grid-template-columns:1fr; } }

.test-card { background:var(--white); border:1px solid var(--wire); padding:44px 36px; position:relative; transition:box-shadow .3s; }

.test-card:hover { box-shadow:0 8px 40px rgba(123,28,62,0.08); }

.test-card::before { content:'\201C'; font-family:var(--serif); font-size:120px; color:var(--burgundy-3); opacity:.2; position:absolute; top:8px; left:26px; line-height:1; }

.test-text { font-family:var(--serif); font-size:16px; font-style:italic; font-weight:400; color:var(--brown); line-height:1.7; margin-bottom:24px; padding-top:16px; position:relative; z-index:1; }

.test-stars { display:flex; gap:3px; margin-bottom:16px; }

.test-star { color:var(--gold); font-size:12px; }

.test-name { font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--charcoal); margin-bottom:3px; }

.test-role { font-size:12px; color:var(--burgundy-3); }



/* APPLY */

.apply-section { background:var(--cream); border-top:1px solid var(--wire); }

.apply-grid { display:grid; grid-template-columns:1fr 1fr; gap:90px; align-items:start; }

@media(max-width:860px){ .apply-grid{ grid-template-columns:1fr; gap:52px; } }

.apply-direct { border:1px solid var(--wire); border-left:3px solid var(--gold); padding:24px; background:var(--gold-pale); margin-top:4px; }

.apply-direct p { font-size:11px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--grey); margin-bottom:14px; }

.apply-direct a { display:flex; gap:10px; align-items:center; font-size:13px; color:var(--brown); text-decoration:none; margin-bottom:9px; transition:color .2s; }

.apply-direct a:hover { color:var(--burgundy); }

.apply-direct a svg { width:12px; height:12px; flex-shrink:0; color:var(--burgundy-3); }

.form-field { margin-bottom:14px; }

.form-field label { display:block; font-size:8.5px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--grey); margin-bottom:6px; }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }

@media(max-width:560px){ .form-row{ grid-template-columns:1fr; } }

.form-input { width:100%; background:var(--white); border:1px solid var(--wire-dark); border-bottom-color:rgba(123,28,62,0.25); padding:12px 16px; font-family:var(--sans); font-size:13px; color:var(--charcoal); outline:none; transition:border-color .25s, box-shadow .25s; }

.form-input:focus { border-color:var(--burgundy-3); box-shadow:0 0 0 3px rgba(196,24,80,0.06); }

.form-input::placeholder { color:var(--grey-light); }

select.form-input option { background:var(--white); color:var(--charcoal); }

textarea.form-input { resize:vertical; min-height:110px; }

.form-note { font-size:10px; color:var(--grey-light); margin-top:10px; }



/* CONTACT STRIP */

.contact-strip { background:var(--charcoal); border-top:3px solid var(--burgundy-3); }

.cs-inner-grid { display:grid; grid-template-columns:auto 1fr; align-items:stretch; }

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

.cs-left { padding:36px 48px; border-right:1px solid rgba(255,255,255,0.08); display:flex; flex-direction:column; justify-content:center; }

@media(max-width:768px){ .cs-left{ border-right:none; border-bottom:1px solid rgba(255,255,255,0.08); padding:28px 22px; } }

.cs-left-name { font-family:var(--serif); font-size:22px; font-weight:400; color:var(--white); margin-bottom:4px; font-style:italic; }

.cs-left-role { font-size:9px; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:rgba(255,255,255,0.45); }

.cs-items { display:grid; grid-template-columns:repeat(4,1fr); }

@media(max-width:900px){ .cs-items{ grid-template-columns:repeat(2,1fr); } }

@media(max-width:480px){ .cs-items{ grid-template-columns:1fr; } }

.cs-item { padding:26px 22px; border-right:1px solid rgba(255,255,255,0.08); text-decoration:none; display:flex; flex-direction:column; gap:5px; transition:background .2s; }

.cs-item:last-child{ border-right:none; }

.cs-item:hover{ background:rgba(255,255,255,0.04); }

.cs-item-label { font-size:8px; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:rgba(255,255,255,0.65); display:flex; align-items:center; gap:6px; }

.cs-item-label svg { width:11px; height:11px; }

.cs-item-value { font-size:13px; color:var(--white); font-weight:500; }



/* FOOTER */

footer { background:var(--charcoal); padding:80px 0 0; }

.footer-grid { display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr; gap:56px; margin-bottom:56px; }

@media(max-width:960px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:40px; } }

@media(max-width:540px){ .footer-grid{ grid-template-columns:1fr; } }

.footer-logo-mark { font-family:var(--serif); font-size:26px; font-weight:400; letter-spacing:5px; text-transform:uppercase; color:var(--white); }

.footer-logo-mark span { color:var(--gold-light); }

.footer-logo-sub { font-size:8px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,0.65); margin-top:4px; margin-bottom:6px; display:block; }

.footer-address { font-size:12px; color:rgba(255,255,255,0.8); line-height:1.7; margin-bottom:20px; font-weight:300; }

.footer-brand-text { font-size:13px; font-weight:300; color:rgba(255,255,255,0.75); line-height:1.7; margin-bottom:24px; max-width:300px; }

.footer-social { display:flex; gap:10px; }

.footer-social a { width:32px; height:32px; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,0.65); text-decoration:none; transition:all .2s; }

.footer-social a:hover { border-color:var(--gold); color:var(--gold); }

.footer-social a svg { width:13px; height:13px; }

.footer-col-title { font-size:9px; font-weight:600; letter-spacing:3.5px; text-transform:uppercase; color:rgba(255,255,255,0.5); margin-bottom:20px; }

.footer-links { list-style:none; }

.footer-links li { margin-bottom:10px; }

.footer-links a { font-size:13px; font-weight:400; color:rgba(255,255,255,0.82); text-decoration:none; transition:color .2s; }

.footer-links a:hover { color:var(--gold-light); }

.footer-bottom { border-top:1px solid rgba(255,255,255,0.12); padding:20px 0; display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; }

.footer-bottom p,.footer-bottom a { font-size:11px; color:rgba(255,255,255,0.55); text-decoration:none; }

.footer-bottom a:hover { color:var(--gold-light); }

.footer-bottom-links { display:flex; gap:24px; }



.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s ease}

.reveal.visible{opacity:1;transform:translateY(0)}

.reveal-delay-1{transition-delay:.1s}

.reveal-delay-2{transition-delay:.2s}

.reveal-delay-3{transition-delay:.3s}

.reveal-delay-4{transition-delay:.4s}



/* ── PAGE HERO ── */
.page-hero{
  background: linear-gradient(135deg, var(--burgundy) 0%, #5A0E2A 100%);
  padding: 80px 0 72px;
  position: relative;
  overflow: hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background: radial-gradient(ellipse at 80% 50%, rgba(184,154,90,0.15) 0%, transparent 65%);
  pointer-events:none;
}
.page-hero::after{
  content:'NEWS';
  font-family:var(--serif);font-size:200px;font-weight:700;
  color:rgba(255,255,255,0.04);
  position:absolute;right:-20px;top:50%;transform:translateY(-50%);
  white-space:nowrap;pointer-events:none;letter-spacing:10px;
}
.page-hero-inner{position:relative;z-index:1}
.page-hero .label{color:var(--gold-light);margin-bottom:12px}
.page-hero .display-title{color:var(--white)}
.page-hero .display-title em{color:var(--gold-light)}
.page-hero .line-burg{background:var(--gold)}
.page-hero-desc{font-size:14.5px;font-weight:300;color:rgba(255,255,255,0.72);max-width:560px;line-height:1.85;margin-top:4px}

/* ── FILTER TABS ── */
.filter-bar{
  background:var(--white);
  border-bottom:1px solid var(--wire);
  padding:0;
  position:sticky;top:76px;z-index:100;
}
@media(max-width:768px){.filter-bar{top:64px}}
.filter-tabs{
  display:flex;gap:0;overflow-x:auto;
  scrollbar-width:none;
}
.filter-tabs::-webkit-scrollbar{display:none}
.filter-tab{
  padding:16px 28px;
  font-size:9.5px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--grey);cursor:pointer;
  border-bottom:2px solid transparent;
  white-space:nowrap;transition:all .25s;
  background:none;border-top:none;border-left:none;border-right:none;
  font-family:var(--sans);
}
.filter-tab:hover{color:var(--burgundy)}
.filter-tab.active{color:var(--burgundy-3);border-bottom-color:var(--burgundy-3)}

/* ── FEATURED / CAROUSEL ── */
.featured-section{padding:72px 0 56px}

.carousel-wrap{position:relative;overflow:hidden}
.carousel-track{
  display:flex;
  gap:0;
  transition:transform 0.5s cubic-bezier(0.76,0,0.24,1);
}

.carousel-card{
  min-width:100%;
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:520px;
  cursor:pointer;
  position:relative;
}
@media(max-width:768px){
  .carousel-card{grid-template-columns:1fr;min-height:auto}
}

.carousel-card-img{
  position:relative;overflow:hidden;
}
.carousel-card-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 0.6s ease;
}
.carousel-card:hover .carousel-card-img img{transform:scale(1.03)}
.carousel-card-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right, transparent 60%, rgba(253,250,246,0.3) 100%);
  pointer-events:none;
}
@media(max-width:768px){.carousel-card-img{min-height:260px}}

.carousel-card-body{
  padding:52px 56px;
  display:flex;flex-direction:column;justify-content:center;
  background:var(--white);
}
@media(max-width:768px){.carousel-card-body{padding:36px 24px}}

.card-category{
  font-size:9px;font-weight:600;letter-spacing:3.5px;text-transform:uppercase;
  color:var(--burgundy-3);margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.card-category::before{content:'';width:24px;height:1px;background:var(--burgundy-3)}

.card-title{
  font-family:var(--serif);
  font-size:clamp(22px,3vw,38px);font-weight:400;line-height:1.15;
  color:var(--charcoal);margin-bottom:16px;
}
.card-excerpt{
  font-size:14px;font-weight:300;color:var(--grey);
  line-height:1.85;margin-bottom:28px;
}
.card-meta{
  display:flex;align-items:center;gap:20px;
  font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:var(--grey-light);margin-bottom:28px;
}
.card-meta-dot{width:3px;height:3px;background:var(--gold);border-radius:50%}
.card-read-btn{
  display:inline-flex;align-items:center;gap:10px;
  font-size:10px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--burgundy);border-bottom:1px solid var(--burgundy-3);
  padding-bottom:4px;transition:gap .25s;
  width:fit-content;
}
.carousel-card:hover .card-read-btn{gap:16px}
.card-read-btn::after{content:'→';font-size:13px}

/* Carousel controls */
.carousel-controls{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:32px;
}
.carousel-dots{display:flex;gap:8px;align-items:center}
.carousel-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--wire-dark);border:1px solid var(--grey-light);
  cursor:pointer;transition:all .25s;
}
.carousel-dot.active{background:var(--burgundy-3);border-color:var(--burgundy-3);width:24px;border-radius:4px}
.carousel-arrows{display:flex;gap:10px}
.carousel-arrow{
  width:44px;height:44px;
  border:1px solid var(--wire-dark);
  background:var(--white);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .25s;font-size:18px;color:var(--brown);
  font-family:var(--sans);
}
.carousel-arrow:hover{background:var(--burgundy);color:var(--white);border-color:var(--burgundy)}

/* ── GRID SECTION ── */
.grid-section{padding:0 0 96px}
.grid-section-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:40px;flex-wrap:wrap;gap:16px;
}
.grid-section-header h2{
  font-family:var(--serif);font-size:28px;font-weight:400;color:var(--charcoal);
}
.grid-section-header h2 em{font-style:italic;color:var(--burgundy)}

.news-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
@media(max-width:960px){.news-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.news-grid{grid-template-columns:1fr}}

.news-card{
  background:var(--white);
  border:1px solid var(--wire);
  cursor:pointer;
  transition:box-shadow .3s, transform .3s;
  overflow:hidden;
}
.news-card:hover{
  box-shadow:0 12px 48px rgba(123,28,62,0.1);
  transform:translateY(-4px);
}
.news-card-img{
  position:relative;overflow:hidden;
  aspect-ratio:16/9;
}
.news-card-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s ease;
}
.news-card:hover .news-card-img img{transform:scale(1.05)}
.news-card-badge{
  position:absolute;top:14px;left:14px;
  background:var(--burgundy-3);
  color:var(--white);
  font-size:8px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  padding:5px 12px;
}
.news-card-body{padding:24px 26px 28px}
.news-card-cat{
  font-size:8.5px;font-weight:600;letter-spacing:3px;text-transform:uppercase;
  color:var(--burgundy-3);margin-bottom:10px;
}
.news-card-title{
  font-family:var(--serif);
  font-size:19px;font-weight:400;line-height:1.25;
  color:var(--charcoal);margin-bottom:12px;
}
.news-card-excerpt{
  font-size:13px;font-weight:300;color:var(--grey);
  line-height:1.75;margin-bottom:18px;
}
.news-card-footer{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:16px;border-top:1px solid var(--wire);
}
.news-card-date{font-size:10px;font-weight:500;letter-spacing:1.5px;color:var(--grey-light);text-transform:uppercase}
.news-card-arrow{font-size:16px;color:var(--burgundy-3);transition:transform .25s}
.news-card:hover .news-card-arrow{transform:translateX(5px)}

/* Promo cards */
.promo-card{
  background:linear-gradient(135deg, var(--burgundy) 0%, #5A0E2A 100%);
  border:none;
}
.promo-card .news-card-cat{color:var(--gold-light)}
.promo-card .news-card-title{color:var(--white)}
.promo-card .news-card-excerpt{color:rgba(255,255,255,0.72)}
.promo-card .news-card-footer{border-top-color:rgba(255,255,255,0.12)}
.promo-card .news-card-date{color:rgba(255,255,255,0.45)}
.promo-card .news-card-arrow{color:var(--gold-light)}

.gold-card{
  background:linear-gradient(135deg, var(--gold) 0%, #8a7040 100%);
  border:none;
}
.gold-card .news-card-cat{color:rgba(255,255,255,0.7)}
.gold-card .news-card-title{color:var(--white)}
.gold-card .news-card-excerpt{color:rgba(255,255,255,0.8)}
.gold-card .news-card-footer{border-top-color:rgba(255,255,255,0.18)}
.gold-card .news-card-date{color:rgba(255,255,255,0.5)}
.gold-card .news-card-arrow{color:var(--white)}

/* ── LIGHTBOX / SLIDESHOW ── */
.lightbox{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,0.96);
  display:none;flex-direction:column;
  align-items:center;justify-content:center;
  overflow:hidden;
}
.lightbox.open{display:flex}

.lb-close{
  position:absolute;top:24px;right:28px;
  width:44px;height:44px;
  border:1px solid rgba(255,255,255,0.2);
  background:none;color:rgba(255,255,255,0.7);
  font-size:22px;cursor:pointer;font-family:var(--sans);
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;z-index:2;
}
.lb-close:hover{background:var(--burgundy-3);border-color:var(--burgundy-3);color:var(--white)}

.lb-counter{
  position:absolute;top:32px;left:50%;transform:translateX(-50%);
  font-size:10px;font-weight:600;letter-spacing:3px;text-transform:uppercase;
  color:rgba(255,255,255,0.4);z-index:2;
}

.lb-track{
  display:flex;width:100%;
  transition:transform 0.5s cubic-bezier(0.76,0,0.24,1);
}
.lb-slide{
  min-width:100%;display:flex;align-items:center;justify-content:center;
  padding:80px 100px;
}
@media(max-width:768px){.lb-slide{padding:70px 20px 60px}}

.lb-content{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;max-width:1100px;width:100%;
  background:var(--charcoal);
  max-height:85vh;overflow:hidden;
}
@media(max-width:768px){
  .lb-content{grid-template-columns:1fr;max-height:none;overflow-y:auto}
}

.lb-img{position:relative;overflow:hidden;min-height:400px}
@media(max-width:768px){.lb-img{min-height:220px}}
.lb-img img{width:100%;height:100%;object-fit:cover;display:block}
.lb-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(0,0,0,0.5) 0%, transparent 50%);
}

.lb-body{
  padding:48px 44px;
  overflow-y:auto;
  display:flex;flex-direction:column;
}
@media(max-width:768px){.lb-body{padding:28px 22px}}

.lb-cat{
  font-size:9px;font-weight:600;letter-spacing:3.5px;text-transform:uppercase;
  color:var(--gold-light);margin-bottom:16px;
  display:flex;align-items:center;gap:10px;
}
.lb-cat::before{content:'';width:20px;height:1px;background:var(--gold)}

.lb-title{
  font-family:var(--serif);
  font-size:clamp(22px,2.5vw,34px);font-weight:400;line-height:1.2;
  color:var(--white);margin-bottom:14px;
}
.lb-title em{font-style:italic;color:var(--gold-light)}

.lb-meta{
  font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,0.35);margin-bottom:24px;
  display:flex;align-items:center;gap:14px;
}
.lb-meta-dot{width:3px;height:3px;background:var(--gold);border-radius:50%}

.lb-text{
  font-size:14px;font-weight:300;color:rgba(255,255,255,0.72);
  line-height:1.9;flex:1;
}
.lb-text p{margin-bottom:16px}
.lb-text strong{color:var(--gold-light);font-weight:500}

.lb-cta{
  margin-top:28px;padding-top:24px;
  border-top:1px solid rgba(255,255,255,0.1);
}
.lb-cta a{
  display:inline-flex;align-items:center;gap:10px;
  font-size:10px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  background:var(--burgundy-3);color:var(--white);
  padding:12px 24px;transition:background .25s;
}
.lb-cta a:hover{background:var(--burgundy-2)}
.lb-cta a::after{content:'→';font-size:13px}

/* Lightbox nav arrows */
.lb-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:52px;height:52px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.15);
  color:var(--white);font-size:22px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:2;transition:all .25s;
}
.lb-arrow:hover{background:var(--burgundy-3);border-color:var(--burgundy-3)}
.lb-arrow-prev{left:20px}
.lb-arrow-next{right:20px}
@media(max-width:768px){
  .lb-arrow-prev{left:8px}
  .lb-arrow-next{right:8px}
}

.lb-dots{
  position:absolute;bottom:20px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;z-index:2;
}
.lb-dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(255,255,255,0.25);cursor:pointer;transition:all .25s;
}
.lb-dot.active{background:var(--burgundy-3);width:20px;border-radius:3px}

/* ── NEWSLETTER BAND ── */
.newsletter-band{
  background:var(--linen);
  border-top:1px solid var(--wire);
  border-bottom:1px solid var(--wire);
  padding:60px 0;
}
.newsletter-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;align-items:center;
}
@media(max-width:768px){.newsletter-inner{grid-template-columns:1fr;gap:32px}}
.newsletter-title{font-family:var(--serif);font-size:28px;font-weight:400;color:var(--charcoal);margin-top:12px}
.newsletter-title em{font-style:italic;color:var(--burgundy)}
.newsletter-text{font-size:14px;font-weight:300;color:var(--grey);margin-top:12px;line-height:1.8}
.newsletter-form{display:flex;gap:12px;flex-wrap:wrap}
.newsletter-input{
  flex:1;min-width:220px;
  background:var(--white);border:1px solid var(--wire-dark);
  padding:13px 18px;font-family:var(--sans);font-size:13px;
  color:var(--charcoal);outline:none;transition:border-color .25s;
}
.newsletter-input:focus{border-color:var(--burgundy-3)}
.newsletter-input::placeholder{color:var(--grey-light)}

.lb-text ul, .lb-text ol{
  padding-left: 30px;
}


body.popup-open {
      overflow: hidden;
    }

    

    .popup {
      display: none;
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, 0.7);
      justify-content: center;
      align-items: center;
      z-index: 9999;
    }

    .popup.show {
      display: flex;
    }

    .popup:hover::after {
      opacity: 1;
    }

    .popup-content {
      position: relative;
      width: 80%;
      max-width: 800px;
      background: #000;
    }

    .popup-content video {
      width: 100%;
      display: block;
    }
    .t-card-icon img {
    width: 25px;
}