/* Event Monogramming — gala-initials theme (v1 bespoke 2026-07-04)
   Art-deco corner brackets, gold hairline frames, dark aubergine stage. */

:root{
  --bg:#171421;
  --surface:#221d31;
  --surface-2:#2a2340;
  --gold:#c9b458;
  --gold-hi:#e3d494;
  --gold-line:rgba(201,180,88,.38);
  --gold-faint:rgba(201,180,88,.16);
  --violet:#8e7cc3;
  --ink:#f4f1ea;
  --ink-dim:rgba(244,241,234,.74);
  --ink-faint:rgba(244,241,234,.52);
  --serif:"Zodiak","Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Nunito Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --wrap:1160px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  overflow-x:clip;
  background:var(--bg);
  color:var(--ink);
  font:400 17px/1.65 var(--sans);
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(1200px 600px at 50% -200px, rgba(142,124,195,.10), transparent 70%),
    radial-gradient(900px 500px at 100% 100%, rgba(201,180,88,.05), transparent 60%);
}
img{max-width:100%;display:block}
a{color:var(--gold-hi);text-decoration:none}
a:hover{color:var(--gold)}

h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.14;letter-spacing:.005em}
h1{font-size:clamp(2.1rem,5.2vw,3.6rem)}
h2{font-size:clamp(1.55rem,3.4vw,2.35rem)}
h3{font-size:1.22rem}
h1 em,h2 em{font-style:italic;color:var(--gold-hi)}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}

/* ---------- eyebrow + deco flourishes ---------- */
.eyebrow{
  font:700 .74rem/1.4 var(--sans);
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;
  display:flex;align-items:center;justify-content:flex-start;flex-wrap:wrap;gap:8px 14px;
}
.eyebrow::before,.eyebrow.center::after{content:"";height:1px;width:34px;background:var(--gold-line);flex:none}
.eyebrow.center{justify-content:center}
.diamond{color:var(--violet);font-style:normal}

/* ---------- scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--violet));transform-origin:0 50%;transform:scaleX(0);z-index:1200}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:1100;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 22px;
  background:rgba(23,20,33,.88);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--gold-faint);
}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand-mono{
  width:44px;height:44px;flex:none;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:1.05rem;font-weight:600;color:var(--gold-hi);
  border:1px solid var(--gold-line);transform:rotate(45deg);
}
.brand-mono span{transform:rotate(-45deg)}
.brand strong{display:block;font-family:var(--serif);font-size:1.06rem;font-weight:600;letter-spacing:.02em}
.brand small{display:block;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
.nav-toggle{display:none;background:none;border:1px solid var(--gold-line);color:var(--gold-hi);font:700 .78rem/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;padding:10px 16px;cursor:pointer}
.site-nav{display:flex;align-items:center;gap:26px}
.site-nav a{font:700 .8rem/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);padding:6px 0;border-bottom:1px solid transparent}
.site-nav a:hover{color:var(--gold-hi);border-bottom-color:var(--gold-line)}
.site-nav a.nav-cta{border:1px solid var(--gold);color:var(--gold-hi);padding:10px 18px}
.site-nav a.nav-cta:hover{background:var(--gold);color:var(--bg)}

/* ---------- deco corner frame ---------- */
.deco{position:relative;border:1px solid var(--gold-faint)}
.deco::before,.deco::after{content:"";position:absolute;width:26px;height:26px;border:2px solid var(--gold);pointer-events:none}
.deco::before{top:-2px;left:-2px;border-right:0;border-bottom:0}
.deco::after{bottom:-2px;right:-2px;border-left:0;border-top:0}
.deco .corner-b::before,.deco .corner-b::after{content:"";position:absolute;width:26px;height:26px;border:2px solid var(--gold);pointer-events:none}
.deco .corner-b::before{top:-2px;right:-2px;border-left:0;border-bottom:0}
.deco .corner-b::after{bottom:-2px;left:-2px;border-right:0;border-top:0}

/* ---------- hero ---------- */
.hero{padding:64px 22px 0;text-align:center}
.hero-frame{max-width:880px;margin:0 auto;padding:56px 30px 48px;background:linear-gradient(180deg,rgba(142,124,195,.06),transparent 55%)}
.mono-lockup{margin:0 auto 26px;width:112px}
.hero .lede{max-width:640px;margin:20px auto 0;font-size:1.12rem;color:var(--ink-dim)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:30px}
.hero-note{margin-top:22px;font-size:.82rem;letter-spacing:.06em;color:var(--ink-faint)}

.button{
  display:inline-flex;align-items:center;justify-content:center;
  font:800 .82rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;
  padding:16px 28px;border:1px solid var(--gold);
  background:var(--gold);color:#171421;transition:background .2s,color .2s;
}
.button:hover{background:var(--gold-hi);color:#171421}
.button.ghost{background:transparent;color:var(--gold-hi)}
.button.ghost:hover{background:rgba(201,180,88,.12);color:var(--gold-hi)}

/* photo band under hero */
.photo-band{max-width:1220px;margin:56px auto 0;padding:0 22px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.photo-band figure{position:relative;border:1px solid var(--gold-line);padding:10px;background:var(--surface)}
.photo-band img{width:100%;height:280px;object-fit:cover}
.photo-band figcaption{padding:12px 4px 4px;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);text-align:left}

/* ---------- sections ---------- */
section.band{padding:76px 0}
section.band.tint{background:linear-gradient(180deg,rgba(34,29,49,.65),rgba(34,29,49,.25));border-top:1px solid var(--gold-faint);border-bottom:1px solid var(--gold-faint)}
.band-head{max-width:720px;margin:0 auto 44px;text-align:center}
.band-head p.sub{margin-top:14px;color:var(--ink-dim)}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}

.card{background:var(--surface);border:1px solid var(--gold-faint);padding:30px 26px;position:relative}
.card:hover{border-color:var(--gold-line)}
.card .kicker{font:800 .68rem/1 var(--sans);letter-spacing:.24em;text-transform:uppercase;color:var(--violet);display:block;margin-bottom:14px}
.card h3{margin-bottom:12px;color:var(--gold-hi)}
.card p{color:var(--ink-dim);font-size:.97rem}
.card ul{margin:12px 0 0 18px;color:var(--ink-dim);font-size:.95rem}
.card li{margin-bottom:6px}
.card a.more{display:inline-block;margin-top:16px;font:800 .74rem/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;border-bottom:1px solid var(--gold-line);padding-bottom:4px}

/* numbered steps */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{border-top:1px solid var(--gold-line);padding-top:18px;position:relative}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:var(--serif);font-size:1.9rem;color:var(--gold);display:block;margin-bottom:8px}
.step h3{font-size:1.05rem;margin-bottom:8px}
.step p{font-size:.92rem;color:var(--ink-dim)}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;border:1px solid var(--gold-line)}
.stat{background:var(--surface);padding:26px 18px;text-align:center}
.stat b{display:block;font-family:var(--serif);font-size:1.7rem;color:var(--gold-hi);margin-bottom:6px}
.stat span{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}

/* trust names */
.trust{display:flex;flex-wrap:wrap;gap:14px 34px;justify-content:center;align-items:center;margin-top:26px}
.trust span{font:700 .85rem/1 var(--sans);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint)}

/* faq */
.faq-list{max-width:760px;margin:0 auto}
.faq-list details{border:1px solid var(--gold-faint);background:var(--surface);margin-bottom:12px;padding:0 22px}
.faq-list summary{cursor:pointer;padding:18px 0;font:600 1.02rem/1.4 var(--serif);color:var(--gold-hi);list-style:none;position:relative;padding-right:30px}
.faq-list summary::after{content:"+";position:absolute;right:2px;top:14px;font-size:1.4rem;color:var(--gold)}
.faq-list details[open] summary::after{content:"–"}
.faq-list details p{padding:0 0 20px;color:var(--ink-dim);font-size:.97rem}

/* gallery grid */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.gallery-grid figure{border:1px solid var(--gold-line);padding:10px;background:var(--surface)}
.gallery-grid img{width:100%;height:300px;object-fit:cover}
.gallery-grid figcaption{padding:12px 4px 4px;font-size:.82rem;color:var(--ink-faint)}
.gallery-grid figure.tall img{height:420px}

/* prose pages */
.prose{max-width:760px;margin:0 auto}
.prose h2{margin:44px 0 16px;color:var(--gold-hi)}
.prose h3{margin:30px 0 10px;color:var(--gold-hi)}
.prose p{margin-bottom:18px;color:var(--ink-dim)}
.prose ul,.prose ol{margin:0 0 18px 22px;color:var(--ink-dim)}
.prose li{margin-bottom:8px}
.prose strong{color:var(--ink)}
.prose .callout{border:1px solid var(--gold-line);background:var(--surface);padding:22px 24px;margin:26px 0}
.prose .callout p{margin:0;color:var(--ink)}
.prose figure{border:1px solid var(--gold-line);padding:10px;background:var(--surface);margin:28px 0}
.prose figcaption{padding:10px 4px 2px;font-size:.82rem;color:var(--ink-faint)}
.prose table{width:100%;border-collapse:collapse;margin:22px 0;font-size:.94rem}
.prose th,.prose td{border:1px solid var(--gold-faint);padding:10px 14px;text-align:left;color:var(--ink-dim)}
.prose th{color:var(--gold-hi);font-family:var(--serif);font-weight:600;background:var(--surface)}

/* breadcrumbs */
.crumbs{max-width:var(--wrap);margin:0 auto;padding:18px 22px 0;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.crumbs a{color:var(--ink-faint)}
.crumbs a:hover{color:var(--gold-hi)}
.crumbs span{color:var(--gold)}

/* page hero (interior) */
.page-hero{padding:58px 22px 30px;text-align:center;max-width:860px;margin:0 auto}
.page-hero .lede{max-width:640px;margin:18px auto 0;color:var(--ink-dim);font-size:1.08rem}

/* ---------- quote form ---------- */
.quote-band{padding:80px 0;border-top:1px solid var(--gold-faint);background:linear-gradient(180deg,rgba(142,124,195,.07),transparent 70%)}
.quote-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:44px;align-items:start}
.quote-intro h2{margin-bottom:16px}
.quote-intro p{color:var(--ink-dim);margin-bottom:14px}
.quote-intro .tel-big{display:inline-block;margin-top:10px;font-family:var(--serif);font-size:1.5rem;color:var(--gold-hi)}
.lead-form{background:var(--surface);border:1px solid var(--gold-line);padding:34px 30px;position:relative}
.hp-wrap{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.lead-form label{display:block;font:700 .72rem/1.3 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
.lead-form input,.lead-form textarea{
  width:100%;margin-top:7px;padding:13px 14px;
  background:var(--bg);border:1px solid var(--gold-faint);color:var(--ink);
  font:400 1rem/1.4 var(--sans);
}
.lead-form input:focus,.lead-form textarea:focus{outline:none;border-color:var(--gold)}
.lead-form textarea{resize:vertical}
.form-submit{width:100%;margin-top:20px;padding:17px;background:var(--gold);border:0;color:#171421;font:800 .84rem/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;cursor:pointer}
.form-submit:hover{background:var(--gold-hi)}
.form-submit:disabled{opacity:.6;cursor:wait}
.form-note{margin-top:14px;font-size:.85rem;color:var(--ink-faint);text-align:center}
.is-success{border-color:var(--violet)}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--gold-line);margin-top:70px;padding:56px 22px 120px;background:linear-gradient(180deg,rgba(34,29,49,.6),var(--bg))}
.footer-grid{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:40px}
.site-footer h4{font-family:var(--serif);font-size:1rem;color:var(--gold-hi);margin-bottom:14px;letter-spacing:.04em}
.site-footer p{font-size:.92rem;color:var(--ink-dim)}
.site-footer nav{display:grid;gap:9px}
.site-footer nav a{font-size:.9rem;color:var(--ink-dim)}
.site-footer nav a:hover{color:var(--gold-hi)}
.footer-mono{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.footer-legal{max-width:var(--wrap);margin:40px auto 0;padding-top:22px;border-top:1px solid var(--gold-faint);font-size:.78rem;color:var(--ink-faint);display:flex;flex-wrap:wrap;gap:8px 24px;justify-content:space-between}

/* link rows on index/list pages */
.link-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.link-tile{display:block;background:var(--surface);border:1px solid var(--gold-faint);padding:28px 26px;color:var(--ink)}
.link-tile:hover{border-color:var(--gold)}
.link-tile h3{color:var(--gold-hi);margin-bottom:8px}
.link-tile p{color:var(--ink-dim);font-size:.95rem}
.link-tile .go{display:inline-block;margin-top:14px;font:800 .72rem/1 var(--sans);letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}

/* ---------- responsive ---------- */
@media (max-width:960px){
  .grid-3,.grid-4,.steps{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .photo-band{grid-template-columns:1fr 1fr}
  .photo-band figure:last-child{display:none}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .quote-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  body{font-size:16px}
  .nav-toggle{display:block}
  .site-nav{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:rgba(23,20,33,.98);border-bottom:1px solid var(--gold-line);
    padding:10px 22px 22px;
  }
  .site-nav.is-open{display:flex}
  .site-nav a{padding:14px 0;border-bottom:1px solid var(--gold-faint)}
  .site-nav a.nav-cta{margin-top:14px;text-align:center}
  .hero{padding-top:44px}
  .hero-frame{padding:40px 18px 34px}
  .photo-band{grid-template-columns:1fr}
  .photo-band figure:last-child{display:block}
  .photo-band img{height:230px}
  .grid-3,.grid-2,.grid-4,.steps,.link-tiles,.gallery-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .field-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  section.band{padding:54px 0}
}
