/* grapeseo.com -- style.css
   DESIGN: DIAGONAL SPLIT HERO + FULL-WIDTH MEGA MENU + CONTAINED -- Site 28
   Playfair Display (new editorial serif) + DM Sans (new humanist sans) -- BOTH NEW in 28-site series
   Palette: Wine #6B2D4E + Gold #C9920A + Cream #FDF9F3 + Charcoal #1C1C2B + Slate #4A4A68 + Mist #8A8AA8
   CSS prefix: grs-   JS: GRS   PHP prefix: grs_   Image prefix: grs-
   MEGA MENU: full-width dropdown with 2-col services grid -- first in series
   DIAGONAL HERO: left dark wine + right image with diagonal clip -- first in series
   /services/index.php: services listing in /services/ folder
   CONTAINED: grs-bound max-width:1160px
   Location: Carrer Gratapalles, 8, 08192 Sant Quirze del Valles, Barcelona, Spain
*/

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400;1,700&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --grs-wine:     #6B2D4E;
  --grs-wine2:    #55244E;
  --grs-wine-lo:  rgba(107,45,78,.06);
  --grs-wine-md:  rgba(107,45,78,.12);
  --grs-gold:     #C9920A;
  --grs-gold2:    #A87600;
  --grs-gold-lo:  rgba(201,146,10,.08);
  --grs-cream:    #FDF9F3;
  --grs-offwhite: #F6F0EC;
  --grs-white:    #FFFFFF;
  --grs-charcoal: #1C1C2B;
  --grs-slate:    #4A4A68;
  --grs-mist:     #8A8AA8;
  --grs-line:     rgba(107,45,78,.09);
  --grs-line2:    rgba(107,45,78,.04);
  --nav-h:        72px;
  --bound-w:      1160px;
  --bound-px:     2.5rem;
  --grs-dur:      .17s;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; }
body { font-family:'DM Sans',system-ui,sans-serif; background:var(--grs-cream); color:var(--grs-slate); line-height:1.72; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
img { display:block; max-width:100%; height:auto; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
ul,ol { list-style:none; }
h1,h2,h3,h4 { font-family:'Playfair Display',Georgia,serif; font-weight:700; line-height:1; }
p { margin-bottom:.8rem; font-size:0.91rem; }
p:last-child { margin-bottom:0; }

/* =====================================================
   CONTAINED LAYOUT
   ===================================================== */
.grs-bound { max-width:var(--bound-w); margin:0 auto; padding:0 var(--bound-px); }

/* -- Labels -- */
.grs-eyebrow { font-family:'DM Sans',sans-serif; font-size:0.56rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--grs-gold); display:inline-flex; align-items:center; gap:.4rem; }
.grs-eyebrow::before { content:''; width:20px; height:1.5px; background:var(--grs-gold); }
.grs-eyebrow-inv { color:rgba(253,249,243,.4); }
.grs-eyebrow-inv::before { background:rgba(201,146,10,.5); }

/* -- Buttons -- */
.grs-btn-wine { display:inline-flex; align-items:center; gap:.3rem; font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:600; background:var(--grs-wine); color:#fff; padding:.78rem 2rem; border-radius:4px; transition:background var(--grs-dur); white-space:nowrap; }
.grs-btn-wine:hover { background:var(--grs-wine2); }
.grs-btn-gold { display:inline-flex; align-items:center; gap:.3rem; font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:600; background:var(--grs-gold); color:#fff; padding:.78rem 2rem; border-radius:4px; transition:background var(--grs-dur); white-space:nowrap; }
.grs-btn-gold:hover { background:var(--grs-gold2); }
.grs-btn-outline { display:inline-flex; align-items:center; gap:.3rem; font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:600; background:transparent; color:var(--grs-slate); padding:.76rem 2rem; border:1.5px solid var(--grs-line); border-radius:4px; transition:all var(--grs-dur); white-space:nowrap; }
.grs-btn-outline:hover { border-color:var(--grs-wine); color:var(--grs-wine); }
.grs-btn-outline-inv { display:inline-flex; align-items:center; gap:.3rem; font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:600; background:transparent; color:rgba(253,249,243,.65); padding:.76rem 2rem; border:1.5px solid rgba(253,249,243,.15); border-radius:4px; transition:all var(--grs-dur); white-space:nowrap; }
.grs-btn-outline-inv:hover { border-color:var(--grs-gold); color:var(--grs-gold); }
.grs-arrow-link { font-family:'DM Sans',sans-serif; font-size:0.78rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--grs-wine); display:inline-flex; align-items:center; gap:.3rem; transition:gap var(--grs-dur); }
.grs-arrow-link:hover { gap:.5rem; }

/* =====================================================
   MEGA MENU NAVIGATION -- full-width dropdown, first in series
   ===================================================== */
.grs-main-nav { position:sticky; top:0; z-index:300; height:var(--nav-h); background:var(--grs-white); border-bottom:1px solid var(--grs-line); transition:box-shadow .25s; }
.grs-main-nav.grs-nav-scrolled { box-shadow:0 2px 24px rgba(107,45,78,.09); }
.grs-nav-inner { max-width:var(--bound-w); margin:0 auto; padding:0 var(--bound-px); height:100%; display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.grs-nav-logo { display:flex; align-items:center; gap:.5rem; flex-shrink:0; }
.grs-nav-grape { width:28px; height:28px; background:var(--grs-wine); border-radius:50%; display:flex; align-items:center; justify-content:center; position:relative; }
.grs-nav-grape::after { content:''; width:10px; height:10px; border:2px solid var(--grs-gold); border-radius:50%; position:absolute; }
.grs-nav-brand { font-family:'Playfair Display',Georgia,serif; font-size:1.1rem; font-weight:700; color:var(--grs-charcoal); }
.grs-nav-brand em { color:var(--grs-wine); font-style:normal; }
.grs-nav-links { display:flex; align-items:center; gap:.2rem; flex:1; justify-content:center; }
/* Nav link font 0.92rem -- bigger than body p 0.91rem + heavier weight */
.grs-nav-lnk { font-family:'Playfair Display',serif; font-size:0.92rem; font-weight:600; color:var(--grs-slate); padding:.35rem .75rem; border-radius:4px; transition:all var(--grs-dur); white-space:nowrap; }
.grs-nav-lnk:hover { color:var(--grs-wine); }
.grs-nav-lnk.grs-cur { color:var(--grs-wine); font-weight:700; }
/* Mega menu trigger */
.grs-mega-trigger { font-family:'Playfair Display',serif; font-size:0.92rem; font-weight:600; color:var(--grs-slate); padding:.35rem .75rem; border-radius:4px; cursor:pointer; display:flex; align-items:center; gap:.2rem; transition:all var(--grs-dur); }
.grs-mega-trigger:hover, .grs-mega-trigger.grs-mega-on { color:var(--grs-wine); }
.grs-mega-chevron { font-size:0.5rem; transition:transform .2s; }
.grs-mega-trigger.grs-mega-on .grs-mega-chevron { transform:rotate(180deg); }
/* Mega menu panel -- full width below nav */
.grs-mega-panel { position:fixed; top:var(--nav-h); left:0; right:0; background:var(--grs-white); border-top:2px solid var(--grs-wine); box-shadow:0 20px 40px rgba(28,28,43,.15); z-index:299; display:none; }
.grs-mega-panel.grs-mega-vis { display:block; animation:grs-mslide .15s ease; }
@keyframes grs-mslide { from{opacity:0;transform:translateY(-5px)} to{opacity:1;transform:none} }
.grs-mega-content { max-width:var(--bound-w); margin:0 auto; padding:2.5rem var(--bound-px) 2rem; display:grid; grid-template-columns:2fr 1fr; gap:3rem; }
.grs-mega-label { font-family:'DM Sans',sans-serif; font-size:0.52rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--grs-mist); margin-bottom:.8rem; }
.grs-mega-svc-grid { display:grid; grid-template-columns:1fr 1fr; gap:.3rem; }
.grs-mega-svc-row { display:flex; align-items:center; gap:.5rem; padding:.5rem .7rem; border-radius:5px; text-decoration:none; transition:background var(--grs-dur); }
.grs-mega-svc-row:hover { background:var(--grs-wine-lo); }
.grs-mega-svc-ico { width:28px; height:28px; background:var(--grs-wine-lo); border-radius:5px; display:flex; align-items:center; justify-content:center; color:var(--grs-wine); flex-shrink:0; }
.grs-mega-svc-ico svg { width:12px; height:12px; }
.grs-mega-svc-nm { font-family:'Playfair Display',serif; font-size:0.82rem; font-weight:700; color:var(--grs-charcoal); line-height:1.2; }
.grs-mega-svc-row:hover .grs-mega-svc-nm { color:var(--grs-wine); }
.grs-mega-svc-pr { font-family:'DM Sans',sans-serif; font-size:0.6rem; color:var(--grs-mist); }
.grs-mega-aside { }
.grs-mega-aside-txt { font-family:'DM Sans',sans-serif; font-size:0.8rem; color:var(--grs-mist); line-height:1.72; margin-bottom:1rem; }
.grs-mega-all { display:flex; align-items:center; gap:.3rem; font-family:'DM Sans',sans-serif; font-size:0.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.1em; color:var(--grs-wine); transition:gap var(--grs-dur); }
.grs-mega-all:hover { gap:.5rem; }
/* Nav right */
.grs-nav-right { display:flex; align-items:center; gap:.5rem; }
.grs-lang-pill { display:flex; align-items:center; gap:.15rem; font-family:'DM Sans',sans-serif; font-size:0.68rem; font-weight:600; color:var(--grs-slate); padding:.22rem .5rem; border:1px solid var(--grs-line); border-radius:20px; transition:all var(--grs-dur); }
.grs-lang-pill svg { width:9px; height:9px; }
.grs-lang-pill:hover { color:var(--grs-wine); border-color:var(--grs-wine-md); }
.grs-nav-cta { display:inline-flex; align-items:center; font-family:'DM Sans',sans-serif; font-size:0.8rem; font-weight:600; background:var(--grs-wine); color:#fff; padding:.45rem 1.2rem; border-radius:4px; transition:background var(--grs-dur); white-space:nowrap; }
.grs-nav-cta:hover { background:var(--grs-wine2); }
.grs-nav-mob-btn { display:none; width:38px; height:38px; align-items:center; justify-content:center; border-radius:4px; transition:background var(--grs-dur); }
.grs-nav-mob-btn:hover { background:var(--grs-wine-lo); }
.grs-nav-mob-btn svg { width:22px; height:22px; color:var(--grs-slate); }
/* Mobile drawer */
.grs-mob-drawer { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:var(--grs-cream); z-index:298; overflow-y:auto; padding:5rem var(--bound-px) 2rem; }
.grs-mob-drawer.grs-drw-open { display:block; }
.grs-mob-x { position:absolute; top:1.2rem; right:1.5rem; width:36px; height:36px; background:var(--grs-offwhite); border-radius:4px; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:1.1rem; color:var(--grs-slate); }
.grs-mob-item { display:block; font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:700; color:var(--grs-charcoal); padding:.5rem 0; border-bottom:1px solid var(--grs-line2); }
.grs-mob-sub { display:block; font-family:'DM Sans',sans-serif; font-size:0.85rem; color:var(--grs-slate); padding:.32rem .75rem; }

/* =====================================================
   DIAGONAL SPLIT HERO -- first in 28-site series
   Left: dark wine panel with serif headline
   Right: image panel clipped with CSS clip-path diagonal
   ===================================================== */
.grs-hero-outer { position:relative; overflow:hidden; background:var(--grs-charcoal); min-height:100vh; display:flex; flex-direction:column; }
.grs-hero-split { display:grid; grid-template-columns:1fr 1fr; min-height:calc(100vh - var(--nav-h)); }
/* Left wine panel */
.grs-hero-left { background:var(--grs-wine); padding:6rem var(--bound-px) 5rem; display:flex; flex-direction:column; justify-content:flex-end; position:relative; overflow:hidden; z-index:1; }
.grs-hero-left::before { content:''; position:absolute; top:-20%; left:-15%; width:70%; aspect-ratio:1; background:radial-gradient(circle,rgba(201,146,10,.12) 0%,transparent 65%); pointer-events:none; }
.grs-hero-eyebrow { margin-bottom:2rem; }
.grs-hero-h1 { font-family:'Playfair Display',Georgia,serif; font-size:clamp(3rem,5vw,5.5rem); font-weight:900; color:#fff; line-height:.92; margin-bottom:1.5rem; }
.grs-hero-h1 em { color:var(--grs-gold); font-style:italic; }
.grs-hero-lead { font-family:'DM Sans',sans-serif; font-size:0.96rem; font-weight:300; color:rgba(253,249,243,.7); max-width:36ch; line-height:1.82; margin-bottom:2.5rem; }
.grs-hero-btns { display:flex; gap:.7rem; flex-wrap:wrap; }
.grs-hero-stats { display:flex; gap:2.5rem; margin-top:3.5rem; padding-top:2rem; border-top:1px solid rgba(253,249,243,.1); }
.grs-hero-stat-n { font-family:'Playfair Display',serif; font-size:2.4rem; font-weight:700; color:var(--grs-gold); line-height:1; }
.grs-hero-stat-l { font-family:'DM Sans',sans-serif; font-size:0.58rem; font-weight:600; letter-spacing:.15em; text-transform:uppercase; color:rgba(253,249,243,.4); }
/* Right image panel -- diagonal clip */
.grs-hero-right { position:relative; overflow:hidden; }
.grs-hero-right img { width:100%; height:100%; object-fit:cover; }
.grs-hero-right::after { content:''; position:absolute; top:0; left:0; bottom:0; width:22%; background:var(--grs-wine); clip-path:polygon(0 0,100% 0,0 100%); z-index:2; }
/* Diagonal overlap decoration */
.grs-hero-bg-deco { position:absolute; bottom:0; left:0; right:0; height:4px; background:linear-gradient(90deg,var(--grs-gold) 0%,var(--grs-wine) 100%); z-index:3; }

/* Ticker */
.grs-ticker { background:var(--grs-charcoal); padding:.36rem 0; overflow:hidden; }
.grs-ticker-belt { display:flex; white-space:nowrap; animation:grs-tick 36s linear infinite; }
@keyframes grs-tick { 0%{transform:translateX(0)}100%{transform:translateX(-50%)} }
.grs-ticker-tok { font-family:'DM Sans',sans-serif; font-size:0.56rem; font-weight:600; color:rgba(253,249,243,.2); letter-spacing:.18em; text-transform:uppercase; padding:0 1.5rem; }
.grs-ticker-tok span { color:var(--grs-gold); opacity:.5; }

/* =====================================================
   ABOUT STRIP (wine bg, horizontal info) -- new style
   ===================================================== */
.grs-about-strip { padding:5rem 0; background:var(--grs-offwhite); }
.grs-about-cols { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.grs-about-img { aspect-ratio:5/4; border-radius:6px; overflow:hidden; background:var(--grs-wine-lo); }
.grs-about-img img { width:100%; height:100%; object-fit:cover; }
.grs-about-h2 { font-family:'Playfair Display',serif; font-size:clamp(2.5rem,5vw,4.5rem); font-weight:900; color:var(--grs-charcoal); line-height:.9; margin-bottom:1.2rem; }
.grs-about-h2 em { color:var(--grs-wine); font-style:italic; }
.grs-about-p { font-family:'DM Sans',sans-serif; font-size:0.9rem; color:var(--grs-slate); line-height:1.88; margin-bottom:.7rem; }
.grs-about-pills { display:flex; flex-wrap:wrap; gap:.35rem; margin-top:1.5rem; }
.grs-about-pill { font-family:'DM Sans',sans-serif; font-size:0.56rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--grs-wine); border:1px solid var(--grs-wine-md); padding:.25rem .75rem; border-radius:30px; }

/* =====================================================
   SERVICES SECTION -- card grid with left border accent
   Different from horizontal rows (Site27) and bento (Site26)
   ===================================================== */
.grs-svc-zone { padding:7rem 0; background:var(--grs-cream); }
.grs-svc-hdr { display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:1.5rem; margin-bottom:3.5rem; }
.grs-svc-h2 { font-family:'Playfair Display',serif; font-size:clamp(3rem,7vw,6.5rem); font-weight:900; color:var(--grs-charcoal); line-height:.88; }
.grs-svc-h2 em { color:var(--grs-wine); font-style:italic; }
.grs-svc-grid { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; }
.grs-svc-card { background:var(--grs-white); border:1.5px solid var(--grs-line); border-radius:6px; padding:2rem; display:block; text-decoration:none; position:relative; overflow:hidden; transition:all .2s; }
.grs-svc-card::before { content:''; position:absolute; left:0; top:0; bottom:0; width:3.5px; background:var(--grs-wine); opacity:0; transition:opacity .2s; border-radius:2px 0 0 2px; }
.grs-svc-card:hover { border-color:var(--grs-wine); box-shadow:0 6px 28px rgba(107,45,78,.1); transform:translateY(-2px); }
.grs-svc-card:hover::before { opacity:1; }
.grs-svc-card-hd { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:1rem; }
.grs-svc-ico { width:36px; height:36px; background:var(--grs-wine-lo); border-radius:6px; display:flex; align-items:center; justify-content:center; color:var(--grs-wine); }
.grs-svc-ico svg { width:16px; height:16px; }
.grs-svc-card:hover .grs-svc-ico { background:var(--grs-wine); color:#fff; }
.grs-svc-del { font-family:'DM Sans',sans-serif; font-size:0.54rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--grs-mist); }
.grs-svc-nm { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--grs-charcoal); margin-bottom:.4rem; line-height:1.2; }
.grs-svc-card:hover .grs-svc-nm { color:var(--grs-wine); }
.grs-svc-tag { font-family:'DM Sans',sans-serif; font-size:0.8rem; color:var(--grs-mist); line-height:1.72; margin-bottom:1.2rem; }
.grs-svc-price { font-family:'Playfair Display',serif; font-size:2rem; font-weight:700; color:var(--grs-wine); }
.grs-svc-card:hover .grs-svc-price { color:var(--grs-gold2); }

/* =====================================================
   RESULTS / CASE STUDIES (charcoal bg, magazine editorial)
   ===================================================== */
.grs-res-zone { padding:7rem 0; background:var(--grs-charcoal); }
.grs-res-h2 { font-family:'Playfair Display',serif; font-size:clamp(3rem,7vw,6.5rem); font-weight:900; color:#fff; line-height:.88; margin-bottom:3.5rem; }
.grs-res-h2 em { color:var(--grs-gold); font-style:italic; }
.grs-res-item { display:grid; grid-template-columns:1fr 1.5fr; gap:4rem; padding:3.5rem 0; border-top:1px solid rgba(253,249,243,.07); align-items:start; }
.grs-res-item:first-of-type { border-top:none; }
.grs-res-kpi { }
.grs-res-kpi-n { font-family:'Playfair Display',serif; font-size:5rem; font-weight:900; color:var(--grs-gold); line-height:1; }
.grs-res-kpi-l { font-family:'DM Sans',sans-serif; font-size:0.6rem; font-weight:600; letter-spacing:.15em; text-transform:uppercase; color:rgba(253,249,243,.3); margin-top:.2rem; }
.grs-res-meta { margin-top:2rem; }
.grs-res-cat { font-family:'DM Sans',sans-serif; font-size:0.54rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--grs-gold); opacity:.65; margin-bottom:.2rem; }
.grs-res-client { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:rgba(253,249,243,.5); }
.grs-res-body { }
.grs-res-title { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700; color:#fff; margin-bottom:.8rem; line-height:1.2; }
.grs-res-p { font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:300; color:rgba(253,249,243,.55); line-height:1.9; }

/* =====================================================
   TESTIMONIALS (cream bg, quote block format)
   ===================================================== */
.grs-quote-zone { padding:7rem 0; background:var(--grs-cream); }
.grs-quote-h2 { font-family:'Playfair Display',serif; font-size:clamp(3rem,7vw,6.5rem); font-weight:900; color:var(--grs-charcoal); line-height:.88; margin-bottom:3.5rem; }
.grs-quote-h2 em { color:var(--grs-wine); font-style:italic; }
.grs-quote-strip { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--grs-line); border-radius:6px; overflow:hidden; }
.grs-quote-block { background:var(--grs-white); padding:2.5rem 2rem; }
.grs-quote-big { font-family:'Playfair Display',serif; font-size:3.5rem; font-weight:900; color:var(--grs-wine); line-height:1; opacity:.25; margin-bottom:.5rem; }
.grs-quote-body { font-family:'DM Sans',sans-serif; font-size:0.88rem; font-style:italic; color:var(--grs-slate); line-height:1.82; margin-bottom:1.8rem; }
.grs-quote-sig { font-family:'DM Sans',sans-serif; font-size:0.68rem; font-weight:600; color:var(--grs-mist); }
.grs-quote-win { font-family:'DM Sans',sans-serif; font-size:0.54rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--grs-gold2); margin-top:.25rem; }

/* =====================================================
   PROCESS (wine bg, vertical numbered timeline)
   ===================================================== */
.grs-proc-zone { padding:7rem 0; background:var(--grs-wine); }
.grs-proc-h2 { font-family:'Playfair Display',serif; font-size:clamp(3rem,7vw,6.5rem); font-weight:900; color:#fff; line-height:.88; margin-bottom:3.5rem; }
.grs-proc-h2 em { color:var(--grs-gold); font-style:italic; }
.grs-proc-list { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; }
.grs-proc-step { background:rgba(253,249,243,.04); border:1px solid rgba(253,249,243,.07); border-radius:6px; padding:2rem; display:flex; gap:1.5rem; transition:background .2s; }
.grs-proc-step:hover { background:rgba(253,249,243,.07); }
.grs-proc-no { font-family:'Playfair Display',serif; font-size:3rem; font-weight:900; color:rgba(201,146,10,.25); line-height:1; flex-shrink:0; }
.grs-proc-body { }
.grs-proc-ttl { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:#fff; margin-bottom:.4rem; }
.grs-proc-desc { font-family:'DM Sans',sans-serif; font-size:0.82rem; font-weight:300; color:rgba(253,249,243,.55); line-height:1.82; }

/* =====================================================
   FAQ (offwhite bg, single column with serif Q)
   ===================================================== */
.grs-faq-zone { padding:7rem 0; background:var(--grs-offwhite); }
.grs-faq-h2 { font-family:'Playfair Display',serif; font-size:clamp(3rem,7vw,6.5rem); font-weight:900; color:var(--grs-charcoal); line-height:.88; margin-bottom:3rem; }
.grs-faq-h2 em { color:var(--grs-wine); font-style:italic; }
.grs-faq-item { border-bottom:1px solid var(--grs-line); }
.grs-faq-btn { width:100%; display:flex; justify-content:space-between; align-items:flex-start; gap:2rem; padding:1.1rem 0; background:none; border:none; cursor:pointer; text-align:left; }
.grs-faq-q { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--grs-charcoal); line-height:1.35; }
.grs-faq-tog { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:700; color:var(--grs-mist); flex-shrink:0; transition:transform .2s,color .2s; margin-top:-2px; }
.grs-faq-item.grs-fq-open .grs-faq-tog { transform:rotate(45deg); color:var(--grs-wine); }
.grs-faq-ans { max-height:0; overflow:hidden; transition:max-height .35s ease; }
.grs-faq-item.grs-fq-open .grs-faq-ans { max-height:300px; }
.grs-faq-ans-txt { font-family:'DM Sans',sans-serif; font-size:0.88rem; color:var(--grs-slate); line-height:1.88; padding:0 0 1.1rem; }

/* =====================================================
   PRICING TABLE (white bg)
   ===================================================== */
.grs-price-zone { padding:5.5rem 0 7rem; background:var(--grs-white); }
.grs-price-h2 { font-family:'Playfair Display',serif; font-size:clamp(3rem,7vw,6.5rem); font-weight:900; color:var(--grs-charcoal); line-height:.88; margin-bottom:3rem; }
.grs-price-h2 em { color:var(--grs-wine); font-style:italic; }
.grs-ptable { width:100%; border-collapse:separate; border-spacing:0; border:1.5px solid var(--grs-line); border-radius:6px; overflow:hidden; }
.grs-ptable th { font-family:'DM Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--grs-mist); background:var(--grs-offwhite); padding:.75rem 1.5rem; text-align:left; border-bottom:1.5px solid var(--grs-line); }
.grs-ptable td { padding:1.1rem 1.5rem; border-bottom:1px solid var(--grs-line2); vertical-align:middle; }
.grs-ptable tr:last-child td { border-bottom:none; }
.grs-ptable tr:hover td { background:var(--grs-wine-lo); }
.grs-ptable tr:hover .grs-pt-nm { color:var(--grs-wine); }
.grs-ptable tr:hover .grs-pt-price { color:var(--grs-gold2); }
.grs-pt-nm { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--grs-charcoal); transition:color var(--grs-dur); }
.grs-pt-del { font-family:'DM Sans',sans-serif; font-size:0.62rem; color:var(--grs-mist); }
.grs-pt-price { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:700; color:var(--grs-wine); transition:color var(--grs-dur); }
.grs-pt-link a { font-family:'DM Sans',sans-serif; font-size:0.68rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--grs-wine); }

/* =====================================================
   BUILDER PAGE
   ===================================================== */
.grs-build-pg { padding:5rem 0 6rem; background:var(--grs-cream); min-height:100vh; }
.grs-build-h1 { font-family:'Playfair Display',serif; font-size:clamp(3.5rem,8vw,8rem); font-weight:900; color:var(--grs-charcoal); line-height:.85; margin-bottom:.4rem; }
.grs-build-h1 em { color:var(--grs-wine); font-style:italic; }
.grs-build-sub { font-family:'DM Sans',sans-serif; font-size:0.96rem; font-weight:300; color:var(--grs-slate); max-width:44ch; line-height:1.78; margin:.4rem 0 3rem; }
.grs-build-cols { display:grid; grid-template-columns:1.6fr 1fr; gap:4.5rem; align-items:start; }
.grs-build-step { margin-bottom:2.5rem; }
.grs-build-step-hd { display:flex; align-items:center; gap:.6rem; margin-bottom:.9rem; border-bottom:2px solid var(--grs-wine); padding-bottom:.5rem; }
.grs-build-step-no { font-family:'Playfair Display',serif; font-size:2rem; font-weight:900; color:rgba(107,45,78,.18); line-height:1; }
.grs-build-step-lbl { font-family:'DM Sans',sans-serif; font-size:0.56rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--grs-slate); }
.grs-pick-row { display:grid; grid-template-columns:1fr auto; gap:1rem; align-items:center; padding:.8rem .4rem; border-bottom:1px solid var(--grs-line2); cursor:pointer; user-select:none; border-radius:5px; transition:background var(--grs-dur); }
.grs-pick-row:hover { background:var(--grs-white); }
.grs-pick-row.grs-sel { background:var(--grs-wine-lo); border-left:2.5px solid var(--grs-wine); padding-left:.3rem; }
.grs-pick-lhs { display:flex; align-items:flex-start; gap:.5rem; }
.grs-pick-radio { width:13px; height:13px; border:1.5px solid var(--grs-mist); border-radius:50%; flex-shrink:0; margin-top:3px; display:flex; align-items:center; justify-content:center; transition:all var(--grs-dur); }
.grs-pick-row.grs-sel .grs-pick-radio { background:var(--grs-wine); border-color:var(--grs-wine); }
.grs-pick-row.grs-sel .grs-pick-radio::after { content:''; width:4px; height:4px; background:#fff; border-radius:50%; }
.grs-pick-nm { font-family:'Playfair Display',serif; font-size:0.9rem; font-weight:700; color:var(--grs-charcoal); }
.grs-pick-row.grs-sel .grs-pick-nm { color:var(--grs-wine); }
.grs-pick-info { font-family:'DM Sans',sans-serif; font-size:0.6rem; color:var(--grs-mist); }
.grs-pick-price { font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:700; color:var(--grs-slate); }
.grs-pick-row.grs-sel .grs-pick-price { color:var(--grs-wine); }
/* Addons */
.grs-addon-row { display:flex; justify-content:space-between; align-items:center; background:var(--grs-white); border:1.5px solid var(--grs-line); border-radius:5px; padding:.6rem .9rem; cursor:pointer; user-select:none; transition:border-color var(--grs-dur); margin-bottom:.3rem; }
.grs-addon-row:hover { border-color:var(--grs-wine-md); }
.grs-addon-row.grs-addon-on { border-color:var(--grs-wine); background:var(--grs-wine-lo); }
.grs-addon-lhs { display:flex; align-items:center; gap:.45rem; }
.grs-addon-box { width:14px; height:14px; border:1.5px solid var(--grs-mist); border-radius:3px; display:flex; align-items:center; justify-content:center; transition:all var(--grs-dur); flex-shrink:0; }
.grs-addon-row.grs-addon-on .grs-addon-box { background:var(--grs-wine); border-color:var(--grs-wine); }
.grs-addon-row.grs-addon-on .grs-addon-box::after { content:'\2713'; font-size:0.52rem; color:#fff; font-weight:900; font-family:sans-serif; }
.grs-addon-nm { font-family:'DM Sans',sans-serif; font-size:0.86rem; font-weight:500; color:var(--grs-slate); }
.grs-addon-price { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--grs-slate); }
.grs-addon-row.grs-addon-on .grs-addon-price { color:var(--grs-wine); }
/* Hours */
.grs-hrs-band { background:var(--grs-charcoal); border-radius:6px; padding:1.2rem; }
.grs-hrs-hd { font-family:'Playfair Display',serif; font-size:0.95rem; font-weight:700; color:#fff; }
.grs-hrs-inf { font-family:'DM Sans',sans-serif; font-size:0.62rem; color:rgba(253,249,243,.35); margin-bottom:.8rem; }
.grs-hrs-ctl { display:flex; align-items:center; gap:.9rem; }
.grs-hrs-dig { font-family:'Playfair Display',serif; font-size:2.6rem; font-weight:900; color:var(--grs-gold); min-width:2ch; text-align:center; line-height:1; }
.grs-hrs-rng { -webkit-appearance:none; appearance:none; flex:1; height:3px; background:rgba(253,249,243,.12); outline:none; cursor:pointer; border-radius:2px; }
.grs-hrs-rng::-webkit-slider-thumb { -webkit-appearance:none; width:14px; height:14px; background:var(--grs-gold); cursor:pointer; border-radius:50%; }
/* Summary */
.grs-sum-box { background:var(--grs-wine); border-radius:8px; padding:2rem; position:sticky; top:calc(var(--nav-h) + 1.5rem); }
.grs-sum-ttl { font-family:'DM Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:rgba(253,249,243,.3); padding-bottom:.6rem; border-bottom:1px solid rgba(253,249,243,.08); margin-bottom:.6rem; }
.grs-sum-body { min-height:48px; margin-bottom:.6rem; }
.grs-sum-row { display:flex; justify-content:space-between; gap:1rem; font-family:'DM Sans',sans-serif; font-size:0.72rem; color:rgba(253,249,243,.5); padding:.22rem 0; border-bottom:1px solid rgba(253,249,243,.05); }
.grs-sum-row-v { font-family:'Playfair Display',serif; font-size:0.95rem; font-weight:700; color:#fff; }
.grs-sum-empty { font-family:'DM Sans',sans-serif; font-size:0.88rem; font-style:italic; color:rgba(253,249,243,.3); }
.grs-sum-total { display:flex; justify-content:space-between; align-items:baseline; border-top:1px solid rgba(253,249,243,.1); padding-top:.7rem; margin-top:.3rem; }
.grs-sum-total-lbl { font-family:'DM Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:rgba(253,249,243,.3); }
.grs-sum-total-val { font-family:'Playfair Display',serif; font-size:3rem; font-weight:900; color:var(--grs-gold); line-height:1; }
.grs-sum-go { width:100%; background:var(--grs-gold); color:#fff; font-family:'DM Sans',sans-serif; font-size:0.88rem; font-weight:600; padding:.9rem; border:none; cursor:pointer; border-radius:4px; transition:background var(--grs-dur); margin-top:1rem; }
.grs-sum-go:hover { background:var(--grs-gold2); }
.grs-sum-go:disabled { opacity:.22; pointer-events:none; }

/* =====================================================
   CHECKOUT
   ===================================================== */
.grs-co-pg { padding:5rem 0; min-height:100vh; background:var(--grs-cream); }
.grs-co-h1 { font-family:'Playfair Display',serif; font-size:clamp(3rem,7vw,7.5rem); font-weight:900; color:var(--grs-charcoal); line-height:.85; margin-bottom:.4rem; }
.grs-co-h1 em { color:var(--grs-wine); font-style:italic; }
.grs-co-sub { font-family:'DM Sans',sans-serif; font-size:0.92rem; font-weight:300; color:var(--grs-slate); max-width:44ch; margin:.4rem 0 2.5rem; line-height:1.78; }
.grs-co-cols { display:grid; grid-template-columns:1.4fr 1fr; gap:4.5rem; align-items:start; }
.grs-field { display:flex; flex-direction:column; gap:.15rem; margin-bottom:.55rem; }
.grs-flbl { font-family:'DM Sans',sans-serif; font-size:0.52rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--grs-slate); }
.grs-finp,.grs-fsel,.grs-fta { background:var(--grs-white); border:1.5px solid var(--grs-line); border-radius:4px; padding:.72rem 1rem; color:var(--grs-slate); font-family:'DM Sans',sans-serif; font-size:0.92rem; outline:none; width:100%; transition:border-color var(--grs-dur); }
.grs-finp:focus,.grs-fsel:focus,.grs-fta:focus { border-color:var(--grs-wine); }
.grs-fpair { display:grid; grid-template-columns:1fr 1fr; gap:.5rem; }
.grs-ftos { display:flex; gap:.5rem; align-items:flex-start; font-family:'DM Sans',sans-serif; font-size:0.8rem; color:var(--grs-slate); cursor:pointer; margin:.8rem 0; line-height:1.65; }
.grs-ftos a { color:var(--grs-wine); }
.grs-ftos input { accent-color:var(--grs-wine); flex-shrink:0; margin-top:3px; }
.grs-pay-btn { width:100%; background:var(--grs-wine); color:#fff; font-family:'DM Sans',sans-serif; font-size:0.9rem; font-weight:600; padding:1rem; border:none; cursor:pointer; border-radius:4px; transition:background var(--grs-dur); display:flex; align-items:center; justify-content:space-between; }
.grs-pay-btn:hover { background:var(--grs-wine2); }
.grs-order-box { background:var(--grs-charcoal); border-radius:8px; padding:2rem; position:sticky; top:calc(var(--nav-h) + 2rem); }
.grs-order-ttl { font-family:'DM Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:rgba(253,249,243,.3); padding-bottom:.5rem; border-bottom:1px solid rgba(253,249,243,.06); margin-bottom:.5rem; }
.grs-order-row { display:flex; justify-content:space-between; gap:1rem; font-family:'DM Sans',sans-serif; font-size:0.72rem; color:rgba(253,249,243,.4); padding:.2rem 0; border-bottom:1px solid rgba(253,249,243,.04); }
.grs-order-rv { font-family:'Playfair Display',serif; font-size:0.95rem; font-weight:700; color:#fff; }
.grs-order-total { font-family:'Playfair Display',serif; font-size:3rem; font-weight:900; color:var(--grs-gold); line-height:1; }

/* =====================================================
   MASTHEAD (inner pages) -- CENTERED
   ===================================================== */
.grs-mast { padding:5.5rem 0 4rem; background:var(--grs-wine); position:relative; overflow:hidden; text-align:center; }
.grs-mast::before { content:''; position:absolute; top:-30%; left:50%; transform:translateX(-50%); width:80%; aspect-ratio:1; background:radial-gradient(circle,rgba(201,146,10,.12) 0%,transparent 65%); pointer-events:none; }
.grs-mast-inner { position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; }
.grs-mast-h1 { font-family:'Playfair Display',serif; font-size:clamp(4rem,12vw,11rem); font-weight:900; color:#fff; line-height:.84; text-align:center; }
.grs-mast-h1 em { color:var(--grs-gold); font-style:italic; }
.grs-mast-sub { font-family:'DM Sans',sans-serif; font-size:0.96rem; font-weight:300; color:rgba(253,249,243,.55); max-width:48ch; line-height:1.88; margin-top:.8rem; text-align:center; }

/* =====================================================
   SERVICE DETAIL
   ===================================================== */
.grs-svc-det { padding:5rem 0 6rem; background:var(--grs-cream); }
.grs-svc-det-cols { display:grid; grid-template-columns:1.9fr 1fr; gap:5rem; }
.grs-svc-det-txt p { font-family:'DM Sans',sans-serif; font-size:0.91rem; color:var(--grs-slate); line-height:1.9; margin-bottom:.9rem; }
.grs-svc-det-txt h3 { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700; color:var(--grs-charcoal); margin:2.5rem 0 .6rem; line-height:1.1; }
.grs-svc-hl { border-left:3px solid var(--grs-gold); padding:.7rem 1.1rem; background:var(--grs-gold-lo); margin-bottom:.5rem; border-radius:0 4px 4px 0; font-family:'DM Sans',sans-serif; font-size:0.88rem; color:var(--grs-slate); line-height:1.65; }
.grs-price-box { background:var(--grs-wine); border-radius:8px; padding:2rem; margin-bottom:1rem; }
.grs-pb-lbl { font-family:'DM Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:rgba(253,249,243,.35); }
.grs-pb-amt { font-family:'Playfair Display',serif; font-size:4rem; font-weight:900; color:var(--grs-gold); line-height:1; }
.grs-pb-del { font-family:'DM Sans',sans-serif; font-size:0.56rem; font-weight:600; color:rgba(253,249,243,.3); letter-spacing:.1em; text-transform:uppercase; margin-bottom:1.5rem; }
.grs-incl-box { background:var(--grs-white); border:1.5px solid var(--grs-line); border-radius:6px; padding:1.3rem; }
.grs-incl-ttl { font-family:'DM Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--grs-wine); margin-bottom:.6rem; }
.grs-incl-item { display:flex; gap:.3rem; align-items:flex-start; font-family:'DM Sans',sans-serif; font-size:0.8rem; color:var(--grs-slate); padding:.14rem 0; border-bottom:1px solid var(--grs-line2); }
.grs-incl-item:last-child { border-bottom:none; }
.grs-incl-item::before { content:''; width:4px; height:4px; border-radius:50%; background:var(--grs-wine); flex-shrink:0; margin-top:7px; }

/* =====================================================
   LEGAL
   ===================================================== */
.grs-legal-pg { padding:5rem 0; background:var(--grs-cream); }
.grs-legal-doc { max-width:740px; }
.grs-legal-doc h2 { font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:700; color:var(--grs-charcoal); margin:2.5rem 0 .5rem; padding-top:2rem; border-top:1px solid var(--grs-line); }
.grs-legal-doc h2:first-child { margin-top:0; padding-top:0; border:none; }
.grs-legal-doc p { font-family:'DM Sans',sans-serif; font-size:0.88rem; color:var(--grs-slate); line-height:1.9; margin-bottom:.9rem; }
.grs-legal-doc ul { font-family:'DM Sans',sans-serif; font-size:0.88rem; color:var(--grs-slate); padding-left:1.5rem; list-style:disc; margin-bottom:.9rem; line-height:1.8; }
.grs-legal-doc a { color:var(--grs-wine); }
.grs-legal-meta { font-family:'DM Sans',sans-serif; font-size:0.7rem; color:var(--grs-mist); margin-bottom:2rem; padding-bottom:.8rem; border-bottom:1px solid var(--grs-line); }

/* =====================================================
   FOOTER
   ===================================================== */
.grs-footer { background:var(--grs-charcoal); padding:5.5rem 0 3rem; }
.grs-footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr; gap:3rem; padding-bottom:4rem; border-bottom:1px solid rgba(253,249,243,.05); margin-bottom:2rem; }
.grs-footer-brand { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:#fff; margin-bottom:.4rem; }
.grs-footer-brand em { color:var(--grs-gold); font-style:italic; }
.grs-footer-blurb { font-family:'DM Sans',sans-serif; font-size:0.72rem; font-weight:300; color:rgba(253,249,243,.25); max-width:22ch; line-height:1.78; margin-bottom:.8rem; }
.grs-footer-biz { font-family:'DM Sans',sans-serif; font-size:0.62rem; color:rgba(253,249,243,.15); line-height:2.2; }
.grs-footer-biz a { color:rgba(253,249,243,.15); transition:color var(--grs-dur); }
.grs-footer-biz a:hover { color:var(--grs-gold); }
.grs-footer-col-h { font-family:'DM Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:rgba(253,249,243,.25); margin-bottom:.9rem; }
.grs-footer-nav { display:flex; flex-direction:column; gap:.5rem; }
.grs-footer-nav a { font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:300; color:rgba(253,249,243,.2); transition:color var(--grs-dur); }
.grs-footer-nav a:hover { color:var(--grs-gold); }
.grs-footer-btm { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.grs-footer-copy { font-family:'DM Sans',sans-serif; font-size:0.62rem; color:rgba(253,249,243,.1); }
.grs-footer-legal { display:flex; gap:1.2rem; }
.grs-footer-legal a { font-family:'DM Sans',sans-serif; font-size:0.62rem; color:rgba(253,249,243,.1); transition:color var(--grs-dur); }
.grs-footer-legal a:hover { color:var(--grs-gold); }

/* =====================================================
   COOKIE & CHAT
   ===================================================== */
.grs-cookie { position:fixed; bottom:0; left:0; right:0; z-index:400; background:var(--grs-charcoal); border-top:2px solid var(--grs-wine); padding:.6rem 2.5rem; display:flex; align-items:center; justify-content:center; gap:2rem; flex-wrap:wrap; transition:transform .3s; }
.grs-cookie.grs-ck-gone { transform:translateY(110%); pointer-events:none; }
.grs-ck-txt { font-family:'DM Sans',sans-serif; font-size:0.72rem; color:rgba(253,249,243,.4); }
.grs-ck-txt a { color:var(--grs-gold); }
.grs-ck-actions { display:flex; gap:.4rem; }
.grs-ck-yes { background:var(--grs-wine); color:#fff; font-family:'DM Sans',sans-serif; font-size:0.64rem; font-weight:600; padding:.32rem .9rem; border:none; cursor:pointer; border-radius:4px; }
.grs-ck-no  { background:transparent; color:rgba(253,249,243,.3); font-family:'DM Sans',sans-serif; font-size:0.64rem; padding:.32rem .75rem; border:1px solid rgba(253,249,243,.1); cursor:pointer; border-radius:4px; }
.grs-chat-fab { position:fixed; bottom:4.5rem; right:2rem; z-index:399; width:48px; height:48px; background:var(--grs-wine); border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; border:none; box-shadow:0 4px 20px rgba(107,45,78,.35); transition:transform .2s; }
.grs-chat-fab:hover { transform:scale(1.08); }
.grs-chat-fab svg { width:18px; height:18px; color:#fff; }
.grs-chat-win { position:fixed; bottom:7.5rem; right:2rem; z-index:399; width:290px; background:var(--grs-white); border:1px solid var(--grs-line); border-top:2px solid var(--grs-wine); border-radius:8px; box-shadow:0 12px 40px rgba(28,28,43,.15); opacity:0; pointer-events:none; transform:translateY(6px) scale(.97); transform-origin:bottom right; transition:opacity .2s,transform .2s; }
.grs-chat-win.grs-chat-vis { opacity:1; pointer-events:auto; transform:none; }
.grs-chat-hdr { padding:.7rem 1rem; background:var(--grs-offwhite); border-radius:6px 6px 0 0; border-bottom:1px solid var(--grs-line2); display:flex; justify-content:space-between; align-items:center; }
.grs-chat-dot { width:7px; height:7px; background:var(--grs-wine); border-radius:50%; animation:grs-pulse 2s infinite; }
@keyframes grs-pulse { 0%,100%{opacity:1}50%{opacity:.3} }
.grs-chat-nm { font-family:'Playfair Display',serif; font-size:0.88rem; font-weight:700; color:var(--grs-charcoal); }
.grs-chat-rol { font-family:'DM Sans',sans-serif; font-size:0.52rem; color:var(--grs-mist); }
.grs-chat-cls { background:none; border:none; color:var(--grs-mist); cursor:pointer; }
.grs-chat-log { padding:.7rem; height:145px; overflow-y:auto; display:flex; flex-direction:column; gap:.38rem; }
.grs-chat-msg { max-width:92%; padding:.38rem .78rem; font-family:'DM Sans',sans-serif; font-size:0.74rem; line-height:1.55; border-radius:4px; }
.grs-chat-msg--bot { background:var(--grs-offwhite); color:var(--grs-slate); align-self:flex-start; }
.grs-chat-msg--me  { background:var(--grs-wine); color:#fff; font-weight:500; align-self:flex-end; }
.grs-chat-form { display:flex; border-top:1px solid var(--grs-line2); }
.grs-chat-inp { flex:1; background:none; border:none; padding:.5rem .78rem; font-family:'DM Sans',sans-serif; font-size:0.74rem; color:var(--grs-slate); outline:none; }
.grs-chat-send { background:var(--grs-wine); color:#fff; border:none; padding:0 .78rem; font-family:'DM Sans',sans-serif; font-size:0.62rem; font-weight:600; cursor:pointer; }

/* =====================================================
   CONFIRM PAGES
   ===================================================== */
.grs-confirm-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:6rem 2rem; background:var(--grs-cream); }
.grs-confirm-box { max-width:440px; width:100%; background:var(--grs-white); border-radius:8px; border-top:3px solid var(--grs-wine); padding:3.5rem; text-align:center; border:1px solid var(--grs-line); }

/* -- Reveal -- */
.grs-rv { opacity:0; transform:translateY(16px); transition:opacity .5s ease,transform .5s ease; }
.grs-rv.grs-vis { opacity:1; transform:none; }
.grs-d1{transition-delay:.08s}.grs-d2{transition-delay:.16s}.grs-d3{transition-delay:.24s}

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media(max-width:1080px) {
  .grs-hero-split { grid-template-columns:1fr; min-height:auto; }
  .grs-hero-right { display:none; }
  .grs-mega-panel { position:absolute; }
  .grs-nav-links { display:none; }
  .grs-nav-mob-btn { display:flex; }
  .grs-about-cols { grid-template-columns:1fr; gap:3rem; }
  .grs-svc-grid { grid-template-columns:1fr; }
  .grs-quote-strip { grid-template-columns:1fr; }
  .grs-proc-list { grid-template-columns:1fr; }
  .grs-footer-grid { grid-template-columns:1fr 1fr; gap:2rem; }
  .grs-build-cols,.grs-co-cols { grid-template-columns:1fr; }
  .grs-svc-det-cols { grid-template-columns:1fr; }
  .grs-res-item { grid-template-columns:1fr; gap:2rem; }
  .grs-mega-content { grid-template-columns:1fr; }
}
@media(max-width:720px) {
  :root { --bound-px:1.25rem; }
  .grs-footer-grid { grid-template-columns:1fr; }
  .grs-fpair { grid-template-columns:1fr; }
}
