/* =========================================================
   1 SEAM ALTERATIONS — "Atelier Seam" design system
   Light · high-end · trustworthy
   Brand teal + warm whites + ink black + gold accent
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  /* Brand */
  --teal:        #2598AE;   /* from the storefront sign, slightly deepened */
  --teal-deep:   #16707F;
  --teal-tint:   #EAF6F8;
  --teal-tint-2: #DCEFF3;

  /* Neutrals */
  --ink:      #15191C;
  --charcoal: #4B555C;
  --muted:    #79858C;
  --cloud:    #FBFCFD;   /* page background */
  --mist:     #F2F6F7;   /* alt section */
  --line:     #E4EBED;
  --white:    #FFFFFF;

  /* Luxury accent */
  --gold:     #BFA05A;
  --gold-deep:#9C7F3F;

  /* Aqua + true black */
  --aqua:     #2BC7E0;
  --aqua-deep:#149FBA;
  --ink-900:  #090C0E;
  --ink-800:  #11161A;

  /* Per-category accents (deep & rich) — used on the services page */
  --cat-bridal:   #8A3B50;
  --cat-suits:    #1A2438;
  --cat-everyday: #136A7C;
  --cat-repairs:  #7C5C22;
  --cat-leather:  #4F2D13;
  --cat-curtains: #404E32;

  /* Lighter versions — used on the home featured cards */
  --cat-bridal-l:   #C57E8E;
  --cat-suits-l:    #5B6E92;
  --cat-everyday-l: #2FA7BE;
  --cat-repairs-l:  #C2A256;
  --cat-leather-l:  #A06B3E;
  --cat-curtains-l: #7E8E63;

  /* Type */
  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --script:"Pinyon Script", "Brush Script MT", cursive;

  /* Layout */
  --container: 1200px;
  --radius: 14px;
  --radius-lg: 22px;
  --shadow-sm: 0 4px 14px rgba(21,25,28,.06);
  --shadow:    0 12px 34px rgba(21,25,28,.10);
  --shadow-lg: 0 26px 60px rgba(21,25,28,.16);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cloud);
  line-height:1.65;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.12;color:var(--ink);letter-spacing:-.01em}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 28px}
.section{padding:108px 0}
.section--tight{padding:72px 0}
.bg-mist{background:var(--mist)}
.bg-teal-tint{background:var(--teal-tint)}
.center{text-align:center}
.eyebrow{
  font-family:var(--sans);font-weight:600;font-size:.74rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--teal-deep);
  display:inline-flex;align-items:center;gap:.6em;margin-bottom:18px;
}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--aqua)}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:30px;height:1px;background:var(--aqua)}
h1{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4vw,3.1rem)}
h3{font-size:clamp(1.3rem,2vw,1.6rem)}
.lead{font-size:1.15rem;color:var(--charcoal);max-width:62ch}
.lead.center{margin-left:auto;margin-right:auto}
.muted{color:var(--muted)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;cursor:pointer;border:none;
  font-family:var(--sans);font-weight:600;font-size:.95rem;letter-spacing:.02em;
  padding:15px 30px;border-radius:100px;transition:.35s var(--ease);
  position:relative;white-space:nowrap;
}
.btn .arrow{transition:transform .35s var(--ease)}
.btn:hover .arrow{transform:translateX(5px)}
.btn-primary{background:linear-gradient(120deg,var(--teal) 0%,var(--aqua-deep) 100%);color:#fff;box-shadow:0 10px 26px rgba(43,199,224,.34)}
.btn-primary:hover{background:linear-gradient(120deg,var(--teal-deep) 0%,var(--aqua-deep) 100%);transform:translateY(-2px);box-shadow:0 16px 36px rgba(20,159,186,.45)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal-deep);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-outline-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55)}
.btn-outline-light:hover{background:rgba(255,255,255,.12);border-color:#fff}

/* ---------- Navbar ---------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 40px;transition:.4s var(--ease);
}
.nav__inner{width:100%;max-width:1320px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.nav.scrolled{background:rgba(255,255,255,.9);backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line),0 8px 30px rgba(21,25,28,.06);padding:14px 40px}
.brand{display:flex;flex-direction:column;line-height:.9;transition:.4s}
.brand .one-seam{font-family:var(--script);font-size:2.05rem;color:var(--ink)}
.brand .one-seam .num{color:var(--teal)}
.brand .alter{font-family:var(--sans);font-weight:600;font-size:.7rem;letter-spacing:.42em;
  text-transform:uppercase;color:var(--charcoal);padding-left:3px;margin-top:-2px}
.nav.scrolled .brand .one-seam{font-size:1.85rem}
/* hero (transparent) state — white text */
.nav.on-hero:not(.scrolled) .brand .one-seam{color:#fff}
.nav.on-hero:not(.scrolled) .brand .alter{color:rgba(255,255,255,.8)}
.nav.on-hero:not(.scrolled) .nav__links a{color:rgba(255,255,255,.92)}
.nav.on-hero:not(.scrolled) .nav__toggle span{background:#fff}

.nav__links{display:flex;align-items:center;gap:38px}
.nav__links a{font-weight:500;font-size:.96rem;position:relative;padding:4px 0;transition:.25s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--teal);transition:width .3s var(--ease)}
.nav__links a:hover::after,.nav__links a.active::after{width:100%}
.nav__links a:hover{color:var(--teal-deep)}
.nav__cta{margin-left:8px}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav__toggle span{width:26px;height:2px;background:var(--ink);border-radius:2px;transition:.3s var(--ease)}
.nav__toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle.open span:nth-child(2){opacity:0}
.nav__toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:rgba(251,252,253,.98);backdrop-filter:blur(10px);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;
  opacity:0;visibility:hidden;transition:.4s var(--ease);
}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{font-family:var(--serif);font-size:2rem;padding:10px;opacity:0;transform:translateY(14px);transition:.5s var(--ease)}
.mobile-menu.open a{opacity:1;transform:none}
.mobile-menu.open a:nth-child(1){transition-delay:.08s}
.mobile-menu.open a:nth-child(2){transition-delay:.14s}
.mobile-menu.open a:nth-child(3){transition-delay:.2s}
.mobile-menu.open a:nth-child(4){transition-delay:.26s}
.mobile-menu .btn{margin-top:18px}

/* ---------- HERO ---------- */
.hero-wrap{position:relative;height:230vh;background:var(--ink-900)}
.hero-sticky{position:sticky;top:0;height:100vh}
.hero{position:relative;height:100vh;display:flex;align-items:center;
  overflow:hidden;background:var(--ink-900)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media video,.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(6,9,11,.82) 0%,rgba(6,9,11,.5) 44%,rgba(6,9,11,.18) 100%),
  radial-gradient(120% 80% at 0% 100%,rgba(43,199,224,.18),transparent 55%)}
.hero__inner{position:relative;z-index:2;color:#fff;max-width:740px}
.hero .eyebrow{color:#fff}
.hero .eyebrow::before{background:rgba(255,255,255,.7)}
.hero h1{color:#fff;margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--teal);font-weight:600}
.hero__sub{font-size:1.2rem;color:rgba(255,255,255,.9);max-width:54ch;margin-bottom:34px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero__scroll{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:2;
  color:rgba(255,255,255,.75);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:10px}
.hero__scroll .line{width:1px;height:46px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- Trust strip ---------- */
.trust{background:var(--white);border-bottom:1px solid var(--line)}
.trust__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.trust__item .num{font-family:var(--serif);font-size:2.6rem;color:var(--teal-deep);line-height:1}
.trust__item .lbl{font-size:.84rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:8px}

/* ---------- Generic two-col ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split--reverse .split__media{order:2}
.media-frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.media-frame video,.media-frame img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:transform 1.2s var(--ease)}
.media-frame:hover video,.media-frame:hover img{transform:scale(1.04)}
.media-frame .tag{position:absolute;left:20px;bottom:20px;background:rgba(255,255,255,.92);
  backdrop-filter:blur(6px);padding:10px 16px;border-radius:100px;font-size:.8rem;font-weight:600;color:var(--ink);box-shadow:var(--shadow-sm)}
.media-frame.gold-edge{outline:1px solid rgba(191,160,90,.4);outline-offset:-1px}
.stack-imgs{position:relative}
.stack-imgs .small{position:absolute;right:-26px;bottom:-30px;width:46%;border-radius:var(--radius);
  box-shadow:var(--shadow-lg);border:6px solid #fff}

.feature-list{margin-top:26px;display:grid;gap:16px}
.feature-list li{display:flex;gap:14px;align-items:flex-start}
.feature-list .ic{flex:0 0 auto;width:34px;height:34px;border-radius:50%;background:var(--teal-tint);
  color:var(--teal-deep);display:grid;place-items:center;font-size:.95rem;margin-top:2px}
.feature-list strong{display:block;font-size:1.02rem}
.feature-list span{color:var(--charcoal);font-size:.95rem}

/* ---------- Section heading ---------- */
.sec-head{max-width:680px;margin:0 auto 56px}
.sec-head.left{margin-left:0}
.sec-head p{margin-top:16px}

/* ---------- Service cards (home preview) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  transition:.4s var(--ease);position:relative}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}
.card__media{height:210px;overflow:hidden;position:relative}
.card__media img,.card__media video{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.card:hover .card__media img,.card:hover .card__media video{transform:scale(1.07)}
.card{--c:var(--teal)}
.card__accent{position:absolute;top:0;left:0;height:4px;width:100%;background:var(--c)}
.card__body{padding:26px 26px 30px}
.card__body h3{margin-bottom:10px}
.card__body p{color:var(--charcoal);font-size:.96rem;margin-bottom:16px}
.card__link{font-weight:600;font-size:.9rem;color:var(--c);display:inline-flex;gap:.5em;align-items:center}
.card__link .arrow{transition:transform .3s var(--ease)}
.card:hover .card__link .arrow{transform:translateX(5px)}

/* ---------- Process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.step{position:relative;padding-top:18px}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--serif);
  font-size:2.4rem;color:var(--teal-tint-2);position:absolute;top:-14px;left:0;font-weight:700}
.step h3{font-size:1.15rem;margin:14px 0 8px;position:relative}
.step p{color:var(--charcoal);font-size:.95rem}
.step .bar{width:40px;height:3px;background:var(--teal);border-radius:3px}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px 30px;position:relative}
.quote .stars{color:var(--gold);letter-spacing:3px;margin-bottom:14px}
.quote p{font-family:var(--serif);font-style:italic;font-size:1.12rem;color:var(--ink);line-height:1.5;margin-bottom:20px}
.quote .who{display:flex;align-items:center;gap:12px}
.quote .who .av{width:42px;height:42px;border-radius:50%;background:var(--teal-tint);color:var(--teal-deep);
  display:grid;place-items:center;font-weight:700;font-family:var(--serif)}
.quote .who .nm{font-weight:600;font-size:.95rem}
.quote .who .mt{font-size:.82rem;color:var(--muted)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(125deg,var(--ink-900) 0%,#0d1c20 55%,var(--ink-800) 100%);color:#fff;text-align:center;border-radius:0}
.cta-band .container{position:relative;z-index:2}
.cta-band h2{color:#fff}
.cta-band h2 em{font-style:italic;color:var(--aqua)}
.cta-band p{color:rgba(255,255,255,.82);max-width:56ch;margin:16px auto 30px}
.cta-band::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 14% 18%,rgba(43,199,224,.28),transparent 42%),
  radial-gradient(circle at 86% 84%,rgba(43,199,224,.18),transparent 46%)}
.cta-band .btn-light:hover{box-shadow:0 14px 34px rgba(43,199,224,.4)}

/* ---------- Page header (inner pages) ---------- */
.page-head{position:relative;padding:188px 0 88px;text-align:center;overflow:hidden;
  background:var(--mist);border-bottom:1px solid var(--line)}
.page-head::after{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 50% -10%,var(--teal-tint),transparent 55%)}
.page-head .container{position:relative;z-index:2}
.page-head h1{font-size:clamp(2.4rem,5vw,3.8rem)}
.page-head p{margin:18px auto 0;max-width:60ch;color:var(--charcoal);font-size:1.12rem}
.breadcrumb{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.breadcrumb a:hover{color:var(--teal-deep)}

/* photo header variant (dark photo + text overlay) */
.page-head--photo{background:var(--ink-900);border-bottom:none;padding:210px 0 96px}
.page-head--photo::after{display:none}
.page-head__media{position:absolute;inset:0;z-index:0;overflow:hidden}
.page-head__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.04)}
.page-head__media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(6,9,11,.7) 0%,rgba(6,9,11,.62) 55%,rgba(6,9,11,.86) 100%),
  radial-gradient(110% 90% at 100% 0%,rgba(43,199,224,.22),transparent 55%)}
.page-head--photo h1{color:#fff}
.page-head--photo p{color:rgba(255,255,255,.86)}
.page-head--photo .breadcrumb{color:rgba(255,255,255,.6)}
.page-head--photo .breadcrumb a:hover{color:var(--aqua)}
.page-head--photo .eyebrow{color:#fff}
.page-head--photo .eyebrow::before,.page-head--photo .eyebrow::after{background:var(--aqua)}

/* ---------- Services page: category sections ---------- */
.cat{--c:var(--teal);position:relative;background:color-mix(in srgb,var(--c) 6%,#fff)}
.cat::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--c);opacity:.85}
.cat + .cat{border-top:1px solid var(--line)}
.cat__head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:38px}
.cat__title{display:flex;align-items:center;gap:18px}
.cat__badge{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;flex:0 0 auto;
  background:color-mix(in srgb,var(--c) 14%,#fff);color:var(--c);font-size:1.5rem}
.cat__title h2{font-size:clamp(1.7rem,3vw,2.4rem)}
.cat__title .kicker{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--c)}
.cat__price-note{font-size:.86rem;color:var(--muted)}
.cat__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start}
.cat__media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);position:relative}
.cat__media img,.cat__media video{width:100%;aspect-ratio:5/4;object-fit:cover;transition:transform 1.2s var(--ease)}
.cat__media:hover img,.cat__media:hover video{transform:scale(1.05)}
.cat__media .ribbon{position:absolute;top:18px;left:18px;background:var(--c);color:#fff;
  padding:7px 14px;border-radius:100px;font-size:.78rem;font-weight:600}
.svc-list{display:grid;gap:2px}
.svc-item{display:flex;align-items:flex-start;gap:14px;
  padding:15px 6px;border-bottom:1px solid color-mix(in srgb,var(--c) 18%,var(--line));transition:.25s}
.svc-item::before{content:"";flex:0 0 auto;width:7px;height:7px;border-radius:50%;background:var(--c);margin-top:9px;transition:.25s}
.svc-item:hover{padding-left:14px}
.svc-item:hover::before{transform:scale(1.5)}
.svc-item:hover .svc-name{color:var(--c)}
.svc-name{font-weight:600;font-size:1.04rem;position:relative;transition:.25s}
.svc-desc{display:block;font-weight:400;font-size:.9rem;color:var(--charcoal);margin-top:3px}

/* category nav pills */
.cat-nav{position:sticky;top:0;z-index:40;background:rgba(251,252,253,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.cat-nav ul{display:flex;gap:8px;overflow-x:auto;padding:14px 0;scrollbar-width:none}
.cat-nav ul::-webkit-scrollbar{display:none}
.cat-nav a{font-size:.86rem;font-weight:600;color:var(--charcoal);padding:9px 16px;border-radius:100px;
  border:1px solid var(--line);white-space:nowrap;transition:.25s;background:#fff}
.cat-nav a:hover{border-color:var(--c,var(--teal));color:var(--teal-deep)}
.cat-nav a .dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px;vertical-align:middle}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:54px;align-items:start}
.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-sm)}
.info-row{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
.info-row:last-child{border-bottom:none}
.info-row .ic{flex:0 0 auto;width:42px;height:42px;border-radius:12px;background:var(--teal-tint);
  color:var(--teal-deep);display:grid;place-items:center;font-size:1.05rem}
.info-row .lbl{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.info-row .val{font-weight:600;font-size:1.02rem}
.info-row .val a:hover{color:var(--teal-deep)}

.hours{width:100%;border-collapse:collapse;margin-top:6px}
.hours td{padding:11px 0;border-bottom:1px solid var(--line);font-size:.96rem}
.hours td:last-child{text-align:right;font-weight:600}
.hours tr.today td{color:var(--teal-deep)}
.hours tr.today td:first-child::after{content:" • Today";font-size:.72rem;color:var(--teal);font-weight:600}
.hours .closed{color:var(--muted);font-weight:500}
.badge-open{display:inline-flex;align-items:center;gap:8px;background:#eafaf0;color:#1b8a4b;
  padding:8px 14px;border-radius:100px;font-size:.82rem;font-weight:600;margin-bottom:20px}
.badge-open .dot{width:9px;height:9px;border-radius:50%;background:#21b365;box-shadow:0 0 0 4px rgba(33,179,101,.18)}
.badge-closed .dot{background:#c2553f;box-shadow:0 0 0 4px rgba(194,85,63,.18)}
.badge-closed{color:#b34a36;background:#fdeee9}

/* form */
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:38px;box-shadow:var(--shadow-sm)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.84rem;font-weight:600;margin-bottom:7px;color:var(--charcoal)}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);
  padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;background:var(--cloud);transition:.25s}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(47,167,190,.12)}
.form .btn{width:100%;justify-content:center;margin-top:6px}
.form__note{font-size:.82rem;color:var(--muted);text-align:center;margin-top:14px}
.form__success{display:none;text-align:center;padding:40px 10px}
.form__success.show{display:block;animation:fadeUp .5s var(--ease)}
.form__success .check{width:64px;height:64px;border-radius:50%;background:#eafaf0;color:#21b365;
  display:grid;place-items:center;font-size:1.8rem;margin:0 auto 18px}

.map-wrap{margin-top:8px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.map-wrap iframe{width:100%;height:420px;border:0;display:block;filter:saturate(.92)}
.map-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}

/* ---------- Footer ---------- */
.footer{background:var(--ink-900);color:rgba(255,255,255,.72);padding:72px 0 30px}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:48px}
.footer .brand .one-seam{color:#fff}
.footer .brand .one-seam .num{color:var(--teal)}
.footer .brand .alter{color:rgba(255,255,255,.6)}
.footer p{font-size:.94rem;margin-top:16px;max-width:34ch}
.footer h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:18px}
.footer ul li{margin-bottom:11px}
.footer ul a,.footer__contact a{font-size:.94rem;transition:.25s}
.footer ul a:hover,.footer__contact a:hover{color:var(--teal)}
.footer__contact div{margin-bottom:12px;font-size:.94rem}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.84rem;color:rgba(255,255,255,.5)}
.footer__bottom a:hover{color:var(--teal)}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in-view{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ---------- Scroll-scrub film section ---------- */
.film{position:relative;height:280vh;background:var(--ink)}
.film__sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center}
.film__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.film__sticky::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(12,20,22,.35),rgba(12,20,22,.55))}
.film__captions{position:relative;z-index:2;text-align:center;color:#fff;max-width:760px;padding:0 24px}
.film__cap{position:absolute;left:50%;top:50%;transform:translate(-50%,-46%);width:100%;
  opacity:0;transition:opacity .6s var(--ease),transform .6s var(--ease)}
.film__cap.active{opacity:1;transform:translate(-50%,-50%)}
.film__cap .eyebrow{color:#fff;justify-content:center}
.film__cap .eyebrow::before,.film__cap .eyebrow::after{background:rgba(255,255,255,.6)}
.film__cap h2{color:#fff;font-size:clamp(1.8rem,4vw,3rem)}
.film__cap p{color:rgba(255,255,255,.85);margin-top:14px;font-size:1.1rem}
.film__progress{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:8px}
.film__progress span{width:34px;height:3px;border-radius:3px;background:rgba(255,255,255,.3)}
.film__progress span.on{background:var(--teal)}

/* ---------- Hero refinements (luxury) ---------- */
/* Scrubbed hero video — driven by scroll, no continuous playback */
.hero__scrub{transform:scale(1.02) translateZ(0);will-change:contents}
.hero__inner{transition:opacity .4s linear}
.hero__rating{display:inline-flex;align-items:center;gap:12px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(8px);padding:9px 16px;border-radius:100px;
  margin-bottom:26px;color:#fff}
.hero__rating .stars{color:var(--gold);letter-spacing:2px;font-size:.95rem}
.hero__rating .txt{font-size:.85rem;color:rgba(255,255,255,.92)}
.hero__trustline{display:flex;gap:22px;flex-wrap:wrap;margin-top:30px;color:rgba(255,255,255,.82);font-size:.86rem}
.hero__trustline span{display:inline-flex;align-items:center;gap:8px}
.hero__trustline span::before{content:"✓";color:var(--teal);font-weight:700}

/* ---------- Our Story + crest ---------- */
.story__crest{width:210px;height:210px;flex:0 0 auto}
.story__crest svg{width:100%;height:100%;display:block}
.story-badges{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.story-badge{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);
  border-radius:100px;padding:10px 18px;box-shadow:var(--shadow-sm);font-size:.9rem;font-weight:600}
.story-badge .n{font-family:var(--serif);color:var(--teal-deep);font-size:1.15rem}
.signature{font-family:var(--script);font-size:2rem;color:var(--ink);margin-top:24px;line-height:1}
.signature small{display:block;font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);margin-top:6px}

/* ---------- Craft scroll-scrub (smooth, clean) ---------- */
.craft{position:relative;height:240vh;background:#100b07}
.craft__sticky{position:sticky;top:0;height:100vh;overflow:hidden}
.craft__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;will-change:contents;transform:translateZ(0)}
.craft__sticky::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(16,11,7,.86) 0%,rgba(16,11,7,.5) 42%,rgba(16,11,7,.15) 100%)}
.craft__panel{position:absolute;z-index:2;left:0;top:0;height:100%;display:flex;align-items:center;
  width:min(620px,92vw);padding:0 clamp(28px,5vw,90px);box-sizing:border-box}
.craft__caps{position:relative;color:#fff;width:100%;min-height:240px}
.craft__eyebrow{font-family:var(--sans);font-weight:600;font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:.7em;margin-bottom:20px}
.craft__eyebrow::before{content:"";width:34px;height:1px;background:var(--gold)}
.craft__cap{position:absolute;top:50%;left:0;width:100%;opacity:0;
  transform:translate3d(22px,-50%,0);
  transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1);
  will-change:opacity,transform;pointer-events:none}
.craft__cap.active{opacity:1;transform:translate3d(0,-50%,0);pointer-events:auto}
.craft__cap h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.9rem);margin-bottom:14px}
.craft__cap h2 em{font-style:italic;color:var(--teal)}
.craft__cap p{color:rgba(255,255,255,.82);font-size:1.08rem;max-width:42ch}
.craft__step{font-family:var(--serif);font-size:.95rem;color:rgba(255,255,255,.55);margin-bottom:6px}
.craft__progress{position:absolute;left:clamp(28px,6vw,96px);bottom:46px;z-index:3;display:flex;gap:10px}
.craft__progress span{width:46px;height:3px;border-radius:3px;background:rgba(255,255,255,.25);transition:.4s}
.craft__progress span.on{background:var(--teal)}

/* ---------- Reviews summary ---------- */
.reviews-summary{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px 40px;
  box-shadow:var(--shadow-sm);max-width:760px;margin:0 auto 46px}
.reviews-summary .score{font-family:var(--serif);font-size:3.4rem;color:var(--ink);line-height:1}
.reviews-summary .stars{color:var(--gold);letter-spacing:3px;font-size:1.1rem}
.reviews-summary .sub{font-size:.9rem;color:var(--muted);margin-top:4px}
.reviews-summary .divider{width:1px;height:54px;background:var(--line)}
.reviews-summary .gwrap{display:flex;align-items:center;gap:12px}
.reviews-summary .glogo{font-family:var(--serif);font-weight:700;font-size:1.4rem}
.reviews-summary .glogo b:nth-child(1){color:#4285F4}.reviews-summary .glogo b:nth-child(2){color:#EA4335}
.reviews-summary .glogo b:nth-child(3){color:#FBBC05}.reviews-summary .glogo b:nth-child(4){color:#4285F4}
.reviews-summary .glogo b:nth-child(5){color:#34A853}.reviews-summary .glogo b:nth-child(6){color:#EA4335}

/* ---------- Lite mode (touch / small screens): smooth autoplay, no pinned scrub ---------- */
.lite-hero .hero-wrap{height:auto}
.lite-hero .hero-sticky{position:static;height:auto}
.lite-hero .hero{height:100svh;min-height:600px}
.lite-craft .craft{height:auto}
.lite-craft .craft__sticky{position:static;height:84svh;min-height:540px}
.lite-craft .craft__panel{align-items:center;padding-bottom:0}
.lite-craft .craft__progress{bottom:34px}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .split,.cat__grid,.contact-grid{grid-template-columns:1fr;gap:38px}
  .split--reverse .split__media{order:0}
  .footer__grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:repeat(2,1fr);gap:34px}
  .stack-imgs .small{display:none}
}
@media(max-width:760px){
  body{font-size:16px}
  .section{padding:74px 0}
  .nav{padding:16px 18px}.nav.scrolled{padding:12px 18px}
  .nav__links{display:none}
  .nav__cta{display:inline-flex;padding:9px 15px;font-size:.82rem;margin-left:auto;margin-right:10px}
  .nav__toggle{display:flex}
  .cards,.quotes,.trust__grid{grid-template-columns:1fr}
  .trust__grid{gap:28px}
  .form .row{grid-template-columns:1fr}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{justify-content:center}
  .cat__head{flex-direction:column;align-items:flex-start}
  .film{height:220vh}
  .craft{height:300vh}
  .craft__panel{width:100%;align-items:flex-end;padding-bottom:130px}
  .craft__sticky::after{background:linear-gradient(rgba(16,11,7,.45),rgba(16,11,7,.88))}
  .reviews-summary{gap:22px;padding:24px}
  .reviews-summary .divider{display:none}
  .story__crest{width:150px;height:150px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* embroidery photo list */
.svc-list--photos{grid-template-columns:1fr 1fr;gap:18px}
.svc-item--photo{align-items:center;gap:18px;border:1px solid color-mix(in srgb,var(--c) 18%,var(--line));border-radius:14px;padding:14px;background:#fff}
.svc-item--photo::before{display:none}
.svc-item--photo:hover{padding-left:14px}
.svc-item--photo img{width:150px;height:110px;object-fit:cover;border-radius:10px;flex:0 0 auto}
.svc-item--photo .svc-name{font-size:1.12rem}
@media (max-width:700px){.svc-list--photos{grid-template-columns:1fr}.svc-item--photo img{width:110px;height:90px}}
