/* ==========================================================================
   MAREA — shared stylesheet (single source of truth)
   Tokens, header, buttons, type and spacing live here. Both pages link this.
   Spacing standard: 100px side gutters · 50px section frame ·
   40px label-to-heading · 40px heading-to-body (home About band = 20px).
   ========================================================================== */

:root{
  --vhcap:100vh;   /* full viewport height (hero) */
  --page:calc(var(--vhcap) - var(--bar));   /* full-page section height = one screen minus the top bar */
  --navy0:#04060e;          /* page base dark (home) */
  --header:#0D1E3D;         /* header strip colour (confirmed) */
  --stroke:rgba(140,185,225,.55);
  --line:rgb(140,185,225);  /* the 1px top line, 100% opaque */
  --commLight:#eef1f4;      /* Commission button interior */
  --orange:#DD7936;         /* section labels + Commission text + WhatsApp button (Marea orange, confirmed by Dean 2026-06-19) */
  --aboutbg:#F0F4FB;        /* light background of About content */
  --hblue:#2D8BC2;          /* headings */
  --label:#344A7F;          /* dark-blue sub-titles, belle de loin, Read more, Back */
  --body:#3E3F3E;           /* black body text */
  --ice:#dceaff;            /* light text on dark */
  --gutter:max(100px, calc((100vw - 1240px) / 2));   /* 100px minimum; grows past a 1240px content frame so content centers on wide screens while backgrounds stay full-bleed */
  --radius:5px;             /* box / card / button corner radius (ref: Commission button). NEVER change per element. */
  --bar:55px;               /* top bar height */
  --btnH:27px;              /* EXACT button height. Commission button, step boxes, Next/Back all use this. */
  --fieldH:44px;            /* EXACT height of every form field box (inputs, selects, country-code, contact buttons) */
  --fieldgap:24px;          /* EXACT horizontal gap between side-by-side form boxes (= First/Last name gap). One token for ALL paired/grouped fields. */
}

/* ---- reset / base ---- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--bar)}
body{font-family:"Helvetica Neue",Arial,system-ui,sans-serif;background:var(--navy0);color:#e9f0fb;-webkit-font-smoothing:antialiased}
body.light{background:var(--aboutbg);color:var(--body)}
body.light.paper{background:#fff}   /* pure-white pages: faq, gallery, contact */
img{display:block}

/* ---- header (shared) ---- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:20;height:var(--bar);display:flex;align-items:center;justify-content:space-between;
 padding:0 var(--gutter);background:rgba(13,30,61,.7);border-bottom:1px solid var(--line)}
body.light .topbar{background:rgba(13,30,61,.85)}   /* more opaque over the light About page */
.logo{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:inline-flex;align-items:center}
.logo img{height:44px;width:auto}
.menu-btn{display:flex;flex-direction:column;justify-content:center;gap:5px;width:28px;height:24px;background:none;border:none;cursor:pointer;padding:0}
.menu-btn span{display:block;width:26px;height:2px;background:#cdddf2;transition:transform .25s,opacity .2s,background .2s}
.menu-btn:hover span{background:#fff}
.menu-btn.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-btn.active span:nth-child(2){opacity:0}
.menu-btn.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.menu{position:fixed;top:var(--bar);left:calc(var(--gutter) - 50px);background:#0D1E3D;padding:14px 0;display:none;z-index:19;border-radius:0 0 var(--radius) var(--radius)}   /* navy rectangle matching the top bar; 50px from the left edge; bottom corners rounded to --radius (same as the Commission button) */
.menu.open{display:block}
.menu a{display:block;color:var(--orange);text-decoration:none;font-size:13px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;padding:14px 70px 14px 50px;white-space:nowrap}   /* orange links; 50px left padding keeps text at the 100px gutter (50px menu offset + 50px padding) */
.menu a:hover{color:#f1ab63}
body.light .menu a:hover{color:#f1ab63}
body.light .menu{background:#0D1E3D}   /* fully opaque navy per Dean */
.nav{flex:1;display:flex;justify-content:center;gap:42px}
.nav a{color:#cdddf2;text-decoration:none;font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;opacity:.92;transition:opacity .2s,color .2s}
.nav a:hover{opacity:1;color:#fff}
.hr-right{display:flex;align-items:center;gap:100px}
.flag{display:inline-flex;align-items:center;justify-content:center;width:30px;height:20px;padding:0;cursor:pointer;
 border:1px solid rgba(255,255,255,.35);border-radius:2px;overflow:hidden;background:none;transition:transform .2s,border-color .2s,box-shadow .2s}
.flag svg{width:100%;height:100%}
.flag:hover{border-color:rgba(255,255,255,.9);box-shadow:0 0 0 2px rgba(150,185,225,.25)}

/* ---- buttons (one base + Commission modifier) ---- */
.btn{cursor:pointer;letter-spacing:.34em;text-transform:uppercase;font-size:12px;font-weight:600;color:var(--ice);
 padding:0 28px;height:var(--btnH);border-radius:var(--radius);border:1px solid var(--stroke);background:rgba(28,111,176,.18);
 backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .25s,border-color .25s,color .25s,box-shadow .25s;
 text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-family:inherit}
.btn:hover{background:rgba(40,130,200,.34);border-color:rgba(185,215,245,.95);box-shadow:0 6px 24px rgba(30,90,160,.35)}
.commission{background:var(--commLight);color:var(--orange);border:1px solid var(--stroke);min-width:180px}   /* one canonical Commission-button width everywhere (header, footer, Shop now). 180 >= the natural width of "COMMISSION", so every label snaps to exactly 180px = identical size */
.commission:hover{background:rgba(28,111,176,.18);color:var(--ice);border-color:var(--stroke);box-shadow:none}

/* ---- shared type ---- */
.eyebrow{color:var(--orange);font-size:12px;letter-spacing:.34em;text-transform:uppercase;font-weight:600}
.display,.h2{color:var(--hblue);font-weight:300;font-size:40px;line-height:1.12;margin:40px 0 40px;letter-spacing:.005em}

/* ==========================================================================
   HOME (index.html)
   ========================================================================== */
.hero{position:relative;width:100%;height:var(--vhcap);min-height:600px;overflow:hidden;background:#070b1a}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.hero-slogan{position:absolute;left:50%;bottom:184px;transform:translateX(-50%) translateY(50%);z-index:4;display:block;width:clamp(260px,22vw,440px);height:auto}   /* centred (translateY 50%) in the middle of the gap between the upper and lower hero widgets; ~184px is the gap mid-point, nudge if needed */

/* ---- home hero: social icons (left) + flag (right), under the bar, scroll with the hero ---- */
.hero-top{position:absolute;top:calc(var(--bar) + 26px);left:var(--gutter);right:var(--gutter);z-index:5;display:flex;align-items:center;justify-content:space-between}
.hero-social{display:flex;align-items:center;gap:26px}
.soc{display:inline-flex;align-items:center;color:#fff;opacity:.9;transition:opacity .2s,transform .2s}
.soc:hover{opacity:1;transform:translateY(-1px)}
.soc svg{height:24px;width:24px;display:block}
.hero-flag{display:flex;align-items:center;gap:26px}   /* flag then login; gap matches the social icon gap; the 180px login sits right-aligned directly under the Commission button */

.cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:4;color:#9db4d6;text-align:center;font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.cue span{display:block;margin:0 auto 8px;width:22px;height:34px;border:1px solid rgba(150,180,215,.45);border-radius:12px;position:relative}
.cue span::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:6px;border-radius:2px;background:#9db4d6;transform:translateX(-50%);animation:cueDot 1.6s ease-in-out infinite}
@keyframes cueDot{0%,100%{transform:translate(-50%,0);opacity:1}50%{transform:translate(-50%,9px);opacity:.3}}

.about-summary{position:relative;background:linear-gradient(180deg,#eef3fb 0%,#f2f5fb 100%);color:var(--body);padding:50px var(--gutter)}
.about-summary .display{margin-bottom:20px}        /* home exception: heading-to-body = 20px */
.about-summary .lead{font-size:17px;line-height:1.6}
.about-summary .lead strong{font-weight:700}
.readmore{position:absolute;bottom:10px;right:var(--gutter);color:var(--label);font-size:12px;letter-spacing:.34em;text-transform:uppercase;font-weight:600;text-decoration:none}
.readmore:hover{color:var(--hblue)}
.placeholder{height:50vh;display:flex;align-items:center;justify-content:center;color:#41557a;background:linear-gradient(180deg,#04060e,#070b1a);font-size:12px;letter-spacing:.2em;text-transform:uppercase}

/* ==========================================================================
   ABOUT (about.html)
   ========================================================================== */
.page{padding-top:var(--bar);position:relative}
.back{position:absolute;bottom:10px;right:var(--gutter);color:var(--label);font-size:12px;letter-spacing:.34em;text-transform:uppercase;font-weight:600;text-decoration:none}
.back:hover{color:var(--hblue)}
.wrap{padding:100px var(--gutter)}   /* About page frame: 100px all four sides */
.intro{font-size:16px;line-height:1.6;max-width:760px}
.blocks{margin-top:0;display:grid;grid-template-columns:1fr 1fr;gap:46px 90px;max-width:1240px}
.block .lab{color:var(--label);font-size:15px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;margin-bottom:10px}
.block p{font-size:16px;line-height:1.62}
.sep{height:1px;background:rgba(52,74,127,.18);margin:0 var(--gutter)}
.founder .quote{font-style:italic;font-weight:700;color:var(--label);font-size:17px;margin:6px 0 4px}
.founder .foot{font-size:16px;line-height:1.65;color:var(--body);margin-bottom:26px}
.founder p:not([class]){font-size:16px;line-height:1.65;max-width:900px;margin-bottom:16px}
.sign{margin-top:18px}
.sign .nm{color:var(--hblue);font-size:20px}
.sign .rl{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--label);margin-top:8px}
.cards{margin-top:40px;display:grid;grid-template-columns:1fr 1fr;gap:42px 80px;max-width:1240px}
.card{background:#fff;padding:38px 44px;border-radius:var(--radius);box-shadow:0 2px 20px rgba(40,70,120,.05)}
.card-title{color:var(--label);font-size:15px;letter-spacing:.2em;text-transform:uppercase;font-weight:700}
.card-body{display:flex;gap:36px;margin-top:32px}
.card-badge{flex:0 0 148px}
.card-badge .num{display:block;color:var(--hblue);font-weight:300;font-size:46px;line-height:1}
.card-badge .nl{display:block;color:var(--label);font-size:10px;letter-spacing:.16em;text-transform:uppercase;margin-top:12px;line-height:1.6;font-weight:600}
.card-desc{font-size:15px;line-height:1.6;color:var(--body)}
.card-desc.ph{color:#8a97a8;font-style:italic}

@media(max-width:980px){
  .blocks,.cards{grid-template-columns:1fr}
  .wrap{padding:40px 32px}
  .display,.h2{font-size:30px}
  .card-body{gap:24px}
}

/* ==========================================================================
   THE MAREA EDGE — home section
   ========================================================================== */
.edge{background:#fff;min-height:var(--page);padding:100px var(--gutter);display:flex;flex-direction:column;justify-content:center}  /* 100px frame; section = full page minus the var(--bar) bar (818 at 1440x900) */
.edge .display{margin-bottom:40px}
/* 50px between boxes (narrower boxes); boxes sized to their content */
.edge-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:50px}
.edge-card{background:#fff;border:1px solid rgba(52,74,127,.2);padding:30px 28px;border-radius:var(--radius);display:flex;flex-direction:column;text-decoration:none;cursor:pointer;position:relative;transition:box-shadow .2s,border-color .2s}
.edge-card:hover{box-shadow:0 10px 34px rgba(40,70,120,.10);border-color:rgba(45,139,194,.5)}
.edge-card .n{color:var(--hblue);font-size:64px;font-weight:100;line-height:1;letter-spacing:.01em}
.edge-card .t{color:var(--label);font-size:15px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;line-height:1.28;margin:18px 0 10px}
.edge-card p{font-size:14px;line-height:1.55;color:var(--body)}
.edge-card .more{position:absolute;right:28px;bottom:10px;color:var(--label);font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:600;text-decoration:none}
.edge-card:hover .more{color:var(--hblue)}

/* ==========================================================================
   THE MAREA EDGE — detail page (edge.html), 8 full-screen sections
   ========================================================================== */
.edge-sec{min-height:var(--page);padding:100px var(--gutter);background:#fff;display:flex;flex-direction:column;justify-content:center;position:relative}
.edge-sec .cue{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);text-align:center;color:var(--label);
 font-size:10px;letter-spacing:.22em;text-transform:uppercase;opacity:0;transition:opacity .45s;pointer-events:none}
.edge-sec.cue-on .cue{opacity:.85}
.edge-sec .cue span{display:block;margin:0 auto 7px;width:20px;height:32px;border:1px solid rgba(52,74,127,.42);border-radius:11px;position:relative}
.edge-sec .cue span::after{content:"";position:absolute;left:50%;top:6px;width:3px;height:6px;border-radius:2px;background:var(--label);transform:translateX(-50%);animation:cueDot 1.6s ease-in-out infinite}
.edge-sec.alt{background:var(--aboutbg)}
.edge-inner{max-width:860px}
.enum{color:var(--hblue);font-weight:100;font-size:64px;line-height:1;letter-spacing:.01em}   /* same big light number as the home boxes */
.edge-sec .eyebrow{margin-top:40px}
.etitle{color:var(--hblue);font-size:40px;font-weight:300;letter-spacing:.005em;line-height:1.12;margin:40px 0 40px}  /* big light-blue heading, like the other pages */
.edge-sec .elead{font-size:17px;line-height:1.62;font-weight:700;max-width:800px;margin-bottom:16px}
.edge-sec .intro + .intro{margin-top:16px}
.edge-sec .intro{font-size:17px;line-height:1.62;max-width:800px}
.edge-pts{margin-top:34px;display:grid;gap:22px;max-width:800px}
.edge-pt .pl{color:var(--label);font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.edge-pt p{font-size:16px;line-height:1.6}
.edge-foot{margin-top:60px;color:var(--label);font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:700}

/* ==========================================================================
   OUR RANGES — home section (Two Tides)
   ========================================================================== */
.ranges{background:#fff;padding:100px var(--gutter);min-height:var(--page);display:flex;flex-direction:column;justify-content:center}
.ranges .display{margin-bottom:30px}   /* Two Tides -> intro = 30px, same as What We Build heading -> AI Reconstruction */
.seam{background:#fff;padding:0 var(--gutter)}
.seam::before{content:"";display:block;height:1px;background:rgba(52,74,127,.18)}   /* 818 at 1440x900, grows if needed */
.ranges-grid{display:grid;grid-template-columns:1fr;gap:40px;max-width:1240px}   /* long boxes, stacked, fixed 40px gap (space-between collapsed the gap once the section height was capped) */
.range-box{display:flex;gap:50px;padding:45px 50px;align-items:stretch;position:relative;border-radius:var(--radius);text-decoration:none;cursor:pointer;transition:background .2s,box-shadow .2s}
.range-box .r-head{flex:0 0 252px;display:flex;flex-direction:column}
.range-box .rlabel{font-size:15px;font-weight:700;letter-spacing:.2em;text-transform:uppercase}
.range-box .rname{font-size:40px;font-weight:300;line-height:1.12;letter-spacing:.005em;margin:auto 0;white-space:nowrap}  /* same size as Two Tides; vertically centred */
.range-box .r-body{flex:1;font-size:17px;line-height:1.7}
/* High Tide = dark blue */
.range-box.high{background:var(--header);box-shadow:0 6px 26px rgba(13,30,61,.18)}
.range-box.high:hover{background:#0A1832;box-shadow:0 12px 38px rgba(13,30,61,.30)}
.range-box.high .rlabel{color:#8fb4da}
.range-box.high .rname{color:#eaf2fc}
.range-box.high .r-body{color:#c5d4ea}
/* Low Tide = white */
.range-box.low{background:var(--aboutbg);box-shadow:0 2px 20px rgba(40,70,120,.06)}
.range-box.low:hover{background:#e6edf8;box-shadow:0 10px 30px rgba(40,70,120,.14)}
.range-box.low .rlabel{color:var(--label)}
.range-box.low .rname{color:var(--hblue)}
.range-box.low .r-body{color:var(--body)}
.ranges .rintro{font-size:17px;line-height:1.6;color:var(--body);margin-bottom:40px}
.range-box .rtag{font-weight:700;margin-top:20px;text-transform:uppercase}
.range-box.high .rtag{color:#ffffff}
.range-box.low .rtag{color:var(--label)}
.range-link{position:absolute;bottom:10px;right:50px;font-size:12px;letter-spacing:.34em;text-transform:uppercase;font-weight:600;text-decoration:none}
.range-box.high .range-link{color:#8fb4da}
.range-box.high:hover .range-link{color:#eaf2fc}
.range-box.low .range-link{color:var(--label)}
.range-box.low:hover .range-link{color:var(--hblue)}
@media(max-width:980px){.range-box{flex-direction:column;gap:40px}.range-box .r-head{flex:0 0 auto}.range-box .rname{font-size:38px;margin:40px 0 0;text-align:left}}   /* stacked: name sits midway between the label and the body, left aligned */

/* ==========================================================================
   WHAT WE BUILD — home section (same look as The Marea Edge)
   ========================================================================== */
.build{background:#fff;min-height:var(--page);padding:100px var(--gutter);display:flex;flex-direction:column;justify-content:center}
.build .display{margin-bottom:24px}
.build-lead{max-width:980px;margin-bottom:40px}
.build-lead p{font-size:16px;line-height:1.6;color:var(--body)}
.build-lead p+p{margin-top:18px}
.build-sub{color:var(--label);font-size:15px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin:30px 0 12px}
.build-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:50px}
.build-card{background:#fff;border:1px solid rgba(52,74,127,.2);padding:50px 24px 40px;border-radius:var(--radius);display:flex;flex-direction:column;justify-content:flex-start;position:relative;text-decoration:none;cursor:pointer;transition:box-shadow .2s,border-color .2s}
.build-card:hover{box-shadow:0 10px 34px rgba(40,70,120,.10);border-color:rgba(45,139,194,.5)}
.build-card .blink{position:absolute;right:24px;bottom:10px;color:var(--label);font-size:12px;letter-spacing:.34em;text-transform:uppercase;font-weight:600}
.build-card:hover .blink{color:var(--hblue)}
.build-card .t{color:var(--label);font-size:15px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;line-height:1.28;margin:0 0 10px}
.build-card p{font-size:14px;line-height:1.55;color:var(--body)}
@media(max-width:980px){.build-grid{grid-template-columns:1fr 1fr}}

/* ==========================================================================
   BESPOKE BUILD PROCESS — horizontal scroll carousel (4 per view)
   ========================================================================== */
.process{background:#fff;min-height:var(--page);padding:100px var(--gutter);display:flex;flex-direction:column;justify-content:center}
.process .display{margin-bottom:14px}
.process .pintro{font-size:17px;line-height:1.6;color:var(--body);max-width:900px;margin-bottom:0}
.proc-carousel{position:relative}
.proc-track{display:flex;gap:50px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;user-select:none;touch-action:pan-x}
.proc-track.dragging{cursor:grabbing;scroll-behavior:auto;scroll-snap-type:none}
.proc-track::-webkit-scrollbar{display:none}
.proc-card{flex:0 0 calc((100% - 150px)/4);scroll-snap-align:start;background:#fff;border:1px solid rgba(52,74,127,.2);border-radius:var(--radius);padding:40px 34px;display:flex;flex-direction:column;min-height:300px}
.proc-card .num{font-size:64px;font-weight:100;color:var(--hblue);line-height:1;letter-spacing:.01em}
.proc-card .st{margin:24px 0 14px;color:var(--label);font-size:16px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;line-height:1.3}
.proc-card .sd{font-size:15px;line-height:1.6;color:var(--body)}
/* minimalist arrows, parked in the 100px gutters so cards align with the boxes above */
.proc-arrow{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;padding:0;cursor:pointer;color:var(--orange);line-height:0;transition:color .2s}
.proc-arrow:hover{color:#c2762e}
.proc-arrow svg{width:26px;height:26px;display:block}
.proc-prev{left:-64px}
.proc-next{right:-64px}
.proc-prev svg{animation:nudgeL 1.9s ease-in-out infinite}
.proc-next svg{animation:nudgeR 1.9s ease-in-out infinite}
@keyframes nudgeR{0%,100%{transform:translateX(0);opacity:.5}50%{transform:translateX(4px);opacity:1}}
@keyframes nudgeL{0%,100%{transform:translateX(0);opacity:.5}50%{transform:translateX(-4px);opacity:1}}
/* payment schedule: one-line bar on desktop, stacked steps on phones */
.process .pnote{font-size:16px;line-height:1.65;color:var(--body);max-width:920px;margin:0 0 48px}
.pay{margin-top:44px;background:var(--aboutbg);border-radius:var(--radius);min-height:42px;padding:9px 30px;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;text-align:center}
.pay .pl{color:var(--label);font-size:15px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;white-space:nowrap}
.pay .pv{color:var(--body);font-size:15px;letter-spacing:.04em;line-height:1.6;text-transform:uppercase}
.pay .psym{color:var(--hblue);font-weight:700;font-size:18px}
.pay-steps{display:none;list-style:none;margin:0;padding:0;flex-direction:column;gap:12px;width:100%}
.pay-steps li{display:flex;align-items:baseline;gap:16px}
.pay-steps li+li{border-top:1px solid rgba(52,74,127,.14);padding-top:12px}
.ps-pct{flex:0 0 48px;color:var(--hblue);font-size:20px;font-weight:300;line-height:1}
.ps-when{color:var(--body);font-size:15px;line-height:1.5}
@media(max-width:980px){.proc-card{flex-basis:calc((100% - 50px)/2)}.proc-prev{left:-52px}.proc-next{right:-52px}}

/* ==========================================================================
   REQUEST A QUOTE — dark navy multi-step form (#quote)
   ========================================================================== */
section.quote{background:var(--header);min-height:var(--page);padding:100px var(--gutter);display:flex;flex-direction:column;justify-content:center}
section.quote .qh{color:#eaf2fc;font-size:40px;font-weight:300;line-height:1.12;letter-spacing:.005em;margin:40px 0 14px}
section.quote .qsub{color:#c5d4ea;font-size:17px;line-height:1.6;max-width:760px;margin-bottom:40px}
/* segmented 4-step indicator: same light blue as the cards above, commission-button height */
.qsteps{display:flex;border-radius:var(--radius);overflow:hidden;margin-bottom:40px;max-width:1240px}
.qstep{flex:1;display:flex;align-items:center;gap:9px;height:var(--btnH);padding:0 18px;background:rgba(255,255,255,.05);color:#8fb4da;border:none;border-right:1px solid rgba(255,255,255,.12);cursor:pointer;text-align:left;font-family:inherit;transition:background .2s,color .2s}
.qstep:last-child{border-right:none}
.qstep .qn{font-size:12px;font-weight:600;line-height:normal;color:#8fb4da}
.qstep .ql{font-size:11px;letter-spacing:.13em;text-transform:uppercase;font-weight:700;line-height:normal;color:#8fb4da}
.qstep.active{background:var(--aboutbg)}
.qstep.active .qn{color:var(--hblue)}
.qstep.active .ql{color:var(--header)}
/* fields */
.qform{max-width:1240px}
.qpanel{display:flex;flex-direction:column;gap:22px}
.qrow{display:flex;gap:var(--fieldgap)}
.qrow .qfield{flex:1}
.qcol{flex:1;display:flex;flex-direction:column;gap:22px}
.qfield > label{display:block;color:#9fb6d6;font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px;white-space:nowrap}
.qfield input,.qfield select,.qfield textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(140,185,225,.3);border-radius:var(--radius);color:#eaf2fc;padding:12px 14px;font-family:inherit;font-size:15px;outline:none;transition:border-color .2s,background .2s}
.qfield input,.qfield select{height:var(--fieldH)}
.qfield input[type=file]{height:auto;padding:12px 14px;line-height:1.3}   /* box height follows the button + equal 12px padding above and below; no fixed height to squeeze it */
.qfield input[type=file]::file-selector-button{margin:0 12px 0 0}
.qfield input::placeholder,.qfield textarea::placeholder{color:#6f86ad}
.qfield input:focus,.qfield select:focus,.qfield textarea:focus{border-color:rgba(185,215,245,.9);background:rgba(255,255,255,.08)}
.qfield select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:38px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239fb6d6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:13px}
.qfield select option{color:#0D1E3D}
.qfield.invalid input,.qfield.invalid select,.qfield.invalid textarea{border-color:var(--orange)}
.qlabel-sec{color:#eaf2fc;font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;margin-top:34px}
.qhint{color:#9fb6d6;font-size:15px;line-height:1.6;margin-bottom:2px}
.qmeta{color:#7f95b5;font-size:13px;line-height:1.5;margin-top:10px}
.qprivacy.qprivacy-strong{color:#eaf2fc;font-weight:700}   /* uploads privacy reassurance: white + bold (higher specificity so it wins over .qprivacy) */
/* phone + custom country-code dropdown (shows only the code when chosen) */
.qphone{display:flex;gap:var(--fieldgap)}
.qcc{position:relative;flex:0 0 96px}
.qcc-btn{position:relative;width:100%;height:var(--fieldH);background:rgba(255,255,255,.05);border:1px solid rgba(140,185,225,.3);border-radius:var(--radius);color:#eaf2fc;font-family:inherit;font-size:15px;cursor:pointer;text-align:left;padding:0 26px 0 14px}
.qcc-btn::after{content:"";position:absolute;right:11px;top:50%;width:6px;height:6px;border-right:1.5px solid #9fb6d6;border-bottom:1.5px solid #9fb6d6;transform:translateY(-70%) rotate(45deg);pointer-events:none}
.qcc-btn:hover{border-color:rgba(185,215,245,.7)}
.qcc-list{position:absolute;top:48px;left:0;z-index:30;width:268px;max-height:264px;overflow-y:auto;background:#0D1E3D;border:1px solid rgba(140,185,225,.3);border-radius:var(--radius);list-style:none;margin:0;padding:6px 0;display:none;box-shadow:0 14px 34px rgba(0,0,0,.45)}
.qcc.open .qcc-list{display:block}
.qcc-list li{padding:9px 14px;color:#c5d4ea;font-size:14px;cursor:pointer;white-space:nowrap}
.qcc-list li:hover{background:rgba(255,255,255,.08);color:#fff}
.qphone input{flex:1}
/* account type + nav: uniform buttons (commission-button height, fixed width by longest label) */
.qacct{display:flex;gap:var(--fieldgap);width:calc(50% - (var(--fieldgap) / 2))}
.qu{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:160px;height:var(--btnH);background:rgba(255,255,255,.05);border:1px solid rgba(140,185,225,.3);border-radius:var(--radius);color:#fff;font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-family:inherit;cursor:pointer;transition:border-color .2s,background .2s;position:relative}
.qu:hover{border-color:rgba(185,215,245,.9);background:rgba(255,255,255,.09)}
.qu-ar{width:13px;height:13px;display:block;flex:0 0 auto}
.qu-opt input{position:absolute;opacity:0;width:0;height:0}
.qu-opt:has(input:checked){border-color:#a7d6f4;background:rgba(167,214,244,.18)}
/* preferred contact: three buttons spanning the company-box width, company-box height */
.qcontact{display:flex;gap:var(--fieldgap)}
.qcbtn{flex:1;display:block;text-transform:uppercase;letter-spacing:.12em;height:var(--fieldH);line-height:calc(var(--fieldH) - 2px);text-align:center;white-space:nowrap;background:rgba(255,255,255,.05);border:1px solid rgba(140,185,225,.3);border-radius:var(--radius);color:#c5d4ea;font-size:14px;cursor:pointer;transition:border-color .2s,background .2s;position:relative}
.qcbtn input{display:none}
.qcbtn:has(input:checked){border-color:#a7d6f4;background:rgba(167,214,244,.16);color:#eaf2fc}
/* radio option cards */
.qrange,.qdates{display:flex;gap:var(--fieldgap)}
.qrange .qopt{flex:1 1 0;min-width:0}
.qdates .qopt{flex:1 1 0;min-width:0}
.qopt{display:flex;flex-direction:column;gap:6px;padding:16px 18px;background:rgba(255,255,255,.04);border:1px solid rgba(140,185,225,.25);border-radius:var(--radius);cursor:pointer;transition:border-color .2s,background .2s;position:relative}
.qopt input{position:absolute;opacity:0;width:0;height:0}
.qopt-t{color:#eaf2fc;font-size:15px;font-weight:700}
.qopt-d{color:#9fb6d6;font-size:12px;line-height:1.4}
.qopt-tag{color:#9fb6d6;font-size:12px;font-weight:400;letter-spacing:.02em}
.qopt:has(input:checked){border-color:#a7d6f4;background:rgba(167,214,244,.12)}
.qcheck{display:flex;align-items:center;color:#c5d4ea;font-size:15px;cursor:pointer;margin-top:4px}
.qcheck input{width:18px;height:18px;margin-right:16px;accent-color:var(--orange);flex:0 0 auto}
.qcheck a{color:#9fb6d6;text-decoration:underline}
/* nav */
.qnav{display:flex;align-items:center;gap:20px;margin-top:40px;max-width:1240px}
.qnext{margin-left:auto}
/* confirmation */
.qdone{max-width:760px}
.qdone h3{color:#eaf2fc;font-size:28px;font-weight:300;margin-bottom:14px}
.qdone p{color:#c5d4ea;font-size:16px;line-height:1.65;margin-bottom:24px}
@media(max-width:980px){.qrow{flex-direction:column;gap:22px}.qdates .qopt{flex-basis:calc(50% - (var(--fieldgap) / 2))}.qstep .ql{display:none}}

/* uploads: file input (half) + selected-files list; commission-style send button; privacy note */
.qrow-up{align-items:flex-start}
.qfilelist{width:100%;min-height:198px;max-height:240px;overflow-y:auto;background:rgba(255,255,255,.05);border:1px solid rgba(140,185,225,.3);border-radius:var(--radius);padding:12px 14px;color:#c5d4ea;font-size:14px;line-height:1.75}
.qfilelist .qfile-empty{color:#6f86ad}
.qfile-item{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qfile-more{color:#9fb6d6;margin-top:4px}
.qprivacy{color:#7f95b5;font-size:13px;line-height:1.6;margin-top:22px;max-width:820px}
.qprivacy a{color:#9fb6d6;text-decoration:underline}

/* ==========================================================================
   CONTACT (contact.html) — white page
   ========================================================================== */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:80px;max-width:1240px;align-items:start;margin-top:8px}
.c-block{margin-bottom:36px}
.c-block:last-child{margin-bottom:0}
.c-lab{color:var(--label);font-size:15px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;margin-bottom:12px}   /* same as .build-sub ("Eyes on every step") */
.c-val{font-size:22px;color:var(--hblue);text-decoration:none;line-height:1.3;display:inline-block}
a.c-val:hover{color:var(--label)}
.c-sub{font-size:17px;line-height:1.6;color:var(--body);margin-top:8px}   /* same as .pintro ("Ten steps...") */
.c-ph{font-size:22px;color:var(--hblue);line-height:1.3}
.c-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:6px}
.c-socials{display:flex;gap:20px;margin-top:4px;align-items:center}
.c-soc{display:inline-flex;color:var(--label);transition:color .2s,transform .2s}
.c-soc:hover{color:var(--hblue);transform:translateY(-1px)}
.c-soc svg{width:24px;height:24px;display:block}
.c-links{list-style:none;display:flex;flex-direction:column;gap:14px}
.c-links a{color:var(--label);font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;text-decoration:none}
.c-links a:hover{color:var(--hblue)}
.c-aside{background:#fff;border:1px solid rgba(52,74,127,.2);border-radius:var(--radius);padding:40px 38px}
.c-aside .c-lab{margin-bottom:16px}
.c-note{font-size:15px;line-height:1.65;color:var(--body)}
@media(max-width:980px){.contact-grid{grid-template-columns:1fr;gap:48px}}
/* contact "send us a message" form (white page) */
.cform{display:flex;flex-direction:column;gap:22px}
.cform .cf-row{display:flex;gap:var(--fieldgap)}
.cform .cf-row>div{flex:1}
.cform label{display:block;color:var(--label);font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:8px}
.cform input,.cform textarea{width:100%;background:#fff;border:1px solid rgba(52,74,127,.28);border-radius:var(--radius);color:var(--body);padding:12px 14px;font-family:inherit;font-size:15px;outline:none;transition:border-color .2s}
.cform input{height:var(--fieldH)}
.cform textarea{resize:vertical;min-height:128px}
.cform input:focus,.cform textarea:focus{border-color:var(--hblue)}
.cform .cf-actions{display:flex;justify-content:flex-end;margin-top:4px}
.cf-done strong{color:var(--hblue);font-weight:400;font-size:20px;display:block;margin-bottom:8px}
.cf-done p{color:var(--body);font-size:15px;line-height:1.6}
/* contact as a white section on the main scrolling page */
.contact{background:#fff;min-height:var(--page);padding:100px var(--gutter);display:flex;flex-direction:column;justify-content:center}
.contact .display{margin-bottom:40px}
.c-formhead{margin-bottom:20px}   /* orange "Send us a message" label */
/* dark-blue site footer (after the contact section) */
.footer{background:var(--header);padding:60px var(--gutter)}
.ft-top{display:flex;justify-content:space-between;align-items:stretch;gap:48px}   /* the slogan (.ft-slogan) now fills the lower part of the left column and drives the footer height */
.ft-left{flex:1 1 auto;min-width:0}
.ft-logo{flex:0 0 auto;display:flex;align-items:center;justify-content:flex-end}   /* logo sits inside the content column, right edge at the 100px gutter */
.ft-logo img{display:block;height:auto;width:auto;max-height:100%;max-width:230px}
.ft-links{display:flex;flex-wrap:wrap;gap:16px 32px}
.ft-links a{color:#cdddf2;text-decoration:none;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;transition:color .2s}
.ft-links a:hover{color:#fff}
.ft-cta{margin-top:40px}
.footer .btn.commission{min-width:180px}     /* Commission + Book now: identical size */
.ft-book{display:flex;flex-direction:column;align-items:flex-start;gap:18px;margin-top:40px}
.ft-booktext{color:#c5d4ea;font-size:15px;line-height:1.6;max-width:600px}
.ft-privacy{color:#eaf2fc;font-weight:700;font-size:14px;line-height:1.65;max-width:720px;margin-top:28px}.ft-privacy a{color:#fff;text-decoration:underline}
.ft-slogan{display:block;width:clamp(260px,22vw,440px);height:auto;margin:44px 0}   /* DESKTOP footer slogan: in the left column, same size as the home hero slogan, left aligned, equal 44px space above and below it (.ft-base margin is 0 so the gap below = this margin) */
.ft-slogan-m{display:none}   /* MOBILE-only copy, shown under the logo (see the column-layout media queries) */
.ft-base{color:#5f76a0;font-size:12px;letter-spacing:.04em;margin-top:0;border-top:1px solid rgba(140,185,225,.18);padding-top:22px}
/* light-page checkbox (contact T&C) */
.cf-check{display:flex;align-items:center;color:var(--body);font-size:13px;line-height:1.5;cursor:pointer;white-space:nowrap}
.cf-check input{width:18px;height:18px;margin-top:1px;margin-right:16px;accent-color:var(--orange);flex:0 0 auto}
.cf-check a{color:var(--hblue);text-decoration:underline}
/* terms & conditions (terms.html) */
.legal-intro{font-size:16px;line-height:1.65;max-width:820px;color:var(--body)}
.legal-note{background:var(--aboutbg);border-left:3px solid var(--orange);border-radius:var(--radius);padding:18px 22px;font-size:14px;line-height:1.6;color:var(--label);max-width:820px;margin-top:24px}
.legal{max-width:820px;margin-top:10px}
.legal h2{color:var(--hblue);font-size:19px;font-weight:400;line-height:1.3;margin:36px 0 10px}
.legal h2 .num{color:var(--label);font-weight:700;margin-right:10px}
.legal p{font-size:15px;line-height:1.7;color:var(--body);margin-bottom:10px}
.legal p a{color:var(--hblue)}

/* ==========================================================================
   OUR WORK — navy banner with a slow right-to-left photo marquee (#ourwork)
   ========================================================================== */
.banner{background:var(--header);padding:100px var(--gutter)}        /* 100px frame; 100px below the strip = the section's bottom padding */
.banner .eyebrow{color:var(--orange)}
.banner .display{color:#eaf2fc;margin:40px 0 30px}             /* eyebrow->title 40px, title->sub 30px */
.ban-sub{color:#8fb4da;font-size:15px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-bottom:12px}
.ban-note{color:#c5d4ea;font-size:16px;line-height:1.65;max-width:900px;margin-bottom:40px}
.ban-strip{overflow:hidden;width:100%}
.ban-track{display:flex;gap:50px;width:max-content;animation:banScroll 240s linear infinite}   /* same 50px gap as the Edge boxes; very slow */
.ban-strip:hover .ban-track{animation-play-state:paused}        /* roll-over stops the movement */
.ban-item{flex:0 0 auto;width:calc(min(100vw - 350px, 1090px) / 4);aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;background:var(--aboutbg);display:flex;align-items:center;justify-content:center;text-decoration:none;border:1px solid rgba(140,185,225,.15);cursor:pointer;transition:box-shadow .2s}   /* width identical to an Edge box: (100vw - 200px gutters - 150px of 3 gaps)/4 */
.ban-item:hover{box-shadow:0 10px 30px rgba(0,0,0,.35)}
.ban-item img{width:100%;height:100%;object-fit:cover;display:block}
.ban-item .gal-ph{color:#9fb1d0;display:flex;align-items:center;justify-content:center}
.ban-item .gal-ph svg{width:74px;height:auto;opacity:.55}
#shopTrack .rm-soon{font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--label);text-align:center;line-height:1.4;padding:0 12px}   /* placeholder label on the Ready Made tiles until real product photos drop in */
@keyframes banScroll{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 25px))}}   /* seamless loop for a duplicated track with a 50px gap */
@media(max-width:980px){.ban-item{width:calc((100vw - 200px - 50px) / 2)}}
@media(max-width:560px){.ban-item{width:calc(100vw - 200px)}}
@media(max-width:820px){.ft-top{flex-direction:column;gap:36px}.ft-logo{align-items:flex-start;justify-content:flex-start}.ft-logo img{height:auto;width:160px;max-height:none}.ft-slogan{display:none}.ft-slogan-m{display:block;width:clamp(260px,22vw,440px);height:auto}.ft-base{margin-top:36px}}   /* footer stacks: slogan moves UNDER the logo; equal gaps = the 36px column gap (privacy->logo->slogan), and ft-base margin 36 = slogan->line */

/* ==========================================================================
   FAQ (faq.html) — white page, AI-search ready (native <details> accordions)
   ========================================================================== */
.faq-intro{font-size:16px;line-height:1.6;max-width:820px;color:var(--body)}
.faq-list{max-width:980px;margin-top:40px}
.faq-sec{margin-top:46px}
.faq-sec:first-child{margin-top:0}
.faq-cat{color:var(--label);font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;margin-bottom:6px}
.faq-item{border-top:1px solid rgba(52,74,127,.16)}
.faq-sec .faq-item:last-child{border-bottom:1px solid rgba(52,74,127,.16)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:flex-start;gap:28px;padding:19px 0;color:var(--hblue);font-size:18px;font-weight:300;line-height:1.32}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--label);font-size:22px;font-weight:300;line-height:1;flex:0 0 auto}
.faq-item[open] summary::after{content:"\2212"}
.faq-item summary:hover{color:var(--label)}
.faq-a{padding:0 44px 22px 0;font-size:16px;line-height:1.66;color:var(--body);max-width:900px}

/* ==========================================================================
   GALLERY (gallery.html) — white page, responsive grid + filter + lightbox
   ========================================================================== */
.gal-filter{margin:0 0 26px}
.gal-flab{color:var(--label);font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;margin-bottom:12px}
/* range: two long buttons spanning the full content width, fieldgap between (same geometry as the commission form) */
.gal-range{display:flex;gap:var(--fieldgap)}
.gal-range .gal-btn{flex:1;flex-direction:column;align-items:flex-start;justify-content:center;text-align:left;height:auto;min-height:64px;padding:13px 20px;gap:5px;white-space:normal}
.gr-t{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;line-height:1.3}
.gr-tag{font-weight:400;opacity:.6}
.gr-d{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;line-height:1.4;opacity:.8}
/* type: equal-width buttons; JS sets the width to the longest label */
.gal-types{display:flex;gap:var(--fieldgap)}
.gal-types .gal-btn{flex:1 1 0;min-width:0;height:auto;min-height:56px;padding:8px 6px;font-size:11px;letter-spacing:.05em;line-height:1.3;white-space:normal}
/* shared toggle button — commission-button geometry, white-page colours */
.gal-btn{appearance:none;font-family:inherit;cursor:pointer;height:var(--btnH);min-height:40px;padding:0 18px;border-radius:var(--radius);border:1px solid rgba(52,74,127,.3);background:var(--aboutbg);color:var(--label);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;display:inline-flex;align-items:center;justify-content:center;text-align:center;transition:background .2s,border-color .2s,color .2s}
.gal-btn:hover{border-color:var(--hblue);color:var(--hblue)}
.gal-btn.on{background:var(--header);border-color:var(--header);color:#eaf2fc}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;margin-top:6px}
.gal-tile{position:relative;display:block;border-radius:var(--radius);overflow:hidden;background:transparent;aspect-ratio:4/3;cursor:pointer;border:1px solid rgba(52,74,127,.1);text-align:left;padding:0;font-family:inherit}
.gal-tile img{width:100%;height:100%;object-fit:cover;display:block}
.gal-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#9fb1d0}
.gal-ph svg{width:74px;height:auto;opacity:.55}
.gal-cap{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;background:linear-gradient(0deg,rgba(13,30,61,.82),rgba(13,30,61,0))}
.gal-cap .gt{color:#fff;font-size:11.5px;letter-spacing:.07em;text-transform:uppercase;font-weight:700;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gal-cap .gal-txt{display:flex;flex-direction:column;gap:2px;min-width:0}
.gal-cap .gal-sub{color:rgba(234,242,252,.72);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gal-badge{font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:4px 8px;border-radius:3px;white-space:nowrap;flex:0 0 auto}
.gal-badge.high{background:#eaf2fc;color:var(--header)}
.gal-badge.low{background:rgba(255,255,255,.16);color:#eaf2fc;border:1px solid rgba(255,255,255,.45)}
.gal-empty{color:var(--label);font-size:15px;padding:24px 0}
.gal-hint{color:var(--label);font-size:13px;line-height:1.6;margin-top:30px;max-width:820px}
@media(max-width:820px){.gal-types{flex-wrap:wrap}.gal-types .gal-btn{flex:1 1 21%}}
@media(max-width:560px){.gal-grid{grid-template-columns:1fr}.gal-range{flex-direction:column}.gal-types .gal-btn{flex:1 1 45%}}

/* lightbox — full image (less 100px gutters), orange process-style arrows, thumb strip; close keeps the current filter */
.lb{position:fixed;inset:0;z-index:60;background:#fff;display:none;flex-direction:column}
.lb.open{display:flex}
.lb-close{position:absolute;top:22px;right:30px;z-index:2;background:none;border:none;color:var(--label);cursor:pointer;line-height:0;padding:8px;transition:color .2s}
.lb-close:hover{color:var(--hblue)}
.lb-close svg{width:26px;height:26px}
.lb-main{flex:1;position:relative;display:flex;align-items:center;justify-content:center;padding:56px var(--gutter) 6px}
.lb-stage{width:100%;max-width:calc(100vw - (2 * var(--gutter)));height:100%;max-height:78vh;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:var(--radius);overflow:hidden}
.lb-stage img{width:100%;height:100%;object-fit:contain;display:block}
.lb-stage .gal-ph svg{width:130px;opacity:.5}
.lb-arrow{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;padding:0;cursor:pointer;color:var(--orange);line-height:0;transition:color .2s}
.lb-arrow:hover{color:#c2762e}
.lb-arrow svg{width:30px;height:30px;display:block}
.lb-prev{left:34px}
.lb-next{right:34px}
.lb-prev svg{animation:nudgeL 1.9s ease-in-out infinite}
.lb-next svg{animation:nudgeR 1.9s ease-in-out infinite}
.lb-cap{text-align:center;color:var(--label);font-size:12px;letter-spacing:.14em;text-transform:uppercase;padding:14px 0 4px}
.lb-cap .lb-range{color:var(--hblue);margin-left:8px}
.lb-cap .lb-title{display:block;font-size:14px;letter-spacing:.1em;font-weight:700}
.lb-cap .lb-meta{display:block;color:var(--hblue);font-size:11px;letter-spacing:.14em;margin-top:6px}
.lb-thumbs{display:flex;gap:12px;overflow-x:auto;padding:14px var(--gutter) 30px;scrollbar-width:none}
.lb-thumbs::-webkit-scrollbar{display:none}
.lb-thumb{position:relative;flex:0 0 auto;width:104px;height:76px;border-radius:4px;overflow:hidden;background:var(--aboutbg);border:2px solid transparent;cursor:pointer;padding:0;transition:border-color .2s}
.lb-thumb .gal-ph svg{width:40px}
.lb-thumb img{width:100%;height:100%;object-fit:cover}
.lb-thumb.active{border-color:var(--hblue)}
@media(max-width:560px){.lb-main{padding:74px 16px 6px}.lb-stage{max-width:calc(100vw - 32px)}.lb-prev{left:4px}.lb-next{right:4px}.lb-thumbs{padding:14px 16px 24px}}

/* ===================== READY MADE / SHOP (shop.html) ===================== */
/* cart button in header */
.hr-right:has(.cart-btn){gap:28px}
.cart-btn{position:relative;appearance:none;border:0;background:none;cursor:pointer;color:var(--ice);width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;padding:0}
.cart-btn svg{width:22px;height:22px}
.cart-btn .cart-count{position:absolute;top:-6px;right:-8px;min-width:16px;height:16px;padding:0 4px;border-radius:9px;background:var(--orange);color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;opacity:0;transform:scale(.6);transition:opacity .2s,transform .2s}
.cart-btn.has .cart-count{opacity:1;transform:scale(1)}
.cart-btn.bump{animation:cbump .3s}
@keyframes cbump{0%,100%{transform:none}40%{transform:scale(1.18)}}

.shop-intro{max-width:760px;margin:40px 0 0;font-size:17px;line-height:1.6;color:var(--body)}
.shop-intro a{color:var(--hblue);text-decoration:none;border-bottom:1px solid rgba(45,139,194,.4)}
.shop-filter{display:flex;gap:12px;margin:34px 0 0;flex-wrap:wrap}

.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px 34px;margin:40px 0 0}
.shop-card{display:flex;flex-direction:column;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 2px 22px rgba(40,70,120,.06)}
.shop-card.unavail{opacity:.92}
.shop-media{position:relative;aspect-ratio:4/3;background:var(--aboutbg);display:flex;align-items:center;justify-content:center}
.shop-media::after,.pdg-main::after{content:"Coming soon";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:rgba(13,30,61,.85);color:#eaf2fc;font-size:12px;font-weight:700;letter-spacing:.26em;text-transform:uppercase;padding:9px 16px;border-radius:4px;white-space:nowrap;pointer-events:none;z-index:1}
.pdg-main::after{font-size:14px;letter-spacing:.28em;padding:11px 20px}
.shop-media img{width:100%;height:100%;object-fit:cover}
.shop-ph{color:rgba(52,74,127,.32)}
.shop-ph svg{width:96px;height:auto}
/* range badge sits in the TOP-RIGHT corner so it never collides with the tags (top-left) */
.shop-range{position:absolute;top:12px;right:12px;left:auto;box-sizing:border-box;height:20px;padding:0 10px;display:inline-flex;align-items:center;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--radius);color:#fff;z-index:1}
.shop-range.high{background:var(--header)}
.shop-range.low{background:var(--hblue)}
.shop-info{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.shop-name{margin:0;font-size:19px;font-weight:300;color:var(--hblue);line-height:1.2}
.shop-meta{margin:8px 0 0;font-size:13px;color:var(--body);opacity:.8}
.shop-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:16px 0 18px}
.shop-price{font-size:20px;font-weight:600;color:var(--label)}
.stock{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:4px 9px;border-radius:var(--radius)}
.stock.in{color:#1f7a4d;background:rgba(31,122,77,.1)}
.stock.low{color:#9a6a16;background:rgba(224,138,54,.14)}
.stock.out{color:#9a2b2b;background:rgba(154,43,43,.1)}
.stock.sold{color:#5a5a5a;background:rgba(90,90,90,.1)}
.shop-card .add{margin-top:auto;width:100%;height:42px;background:var(--header);border:1px solid var(--header);color:#eaf2fc}
.shop-card .add:hover{background:#16345f;border-color:#16345f}
.shop-card .add[disabled]{background:transparent;border:1px solid rgba(52,74,127,.25);color:rgba(52,74,127,.55);cursor:not-allowed}
.shop-empty{margin:40px 0;color:var(--label)}
@media(max-width:960px){.shop-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.shop-grid{grid-template-columns:1fr}.wrap .shop-intro{font-size:16px}}

/* cart drawer */
.cart-scrim{position:fixed;inset:0;background:rgba(8,16,32,.45);opacity:0;visibility:hidden;transition:opacity .25s;z-index:60}
.cart-scrim.show{opacity:1;visibility:visible}
.cart{position:fixed;top:0;right:0;height:100%;width:400px;max-width:90vw;background:#fff;z-index:61;transform:translateX(100%);transition:transform .28s ease;display:flex;flex-direction:column;box-shadow:-8px 0 40px rgba(20,40,80,.18)}
.cart.open{transform:none}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:22px 26px;border-bottom:1px solid rgba(52,74,127,.14)}
.cart-title{font-size:13px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--label)}
.cart-x{appearance:none;border:0;background:none;cursor:pointer;color:var(--label);width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;padding:0}
.cart-x svg{width:20px;height:20px}
.cart-body{flex:1;overflow-y:auto;padding:10px 26px}
.cart-empty{color:var(--body);opacity:.7;font-size:15px;margin-top:30px;text-align:center}
.ci{display:flex;gap:14px;padding:18px 0;border-bottom:1px solid rgba(52,74,127,.1)}
.ci-thumb{flex:0 0 64px;width:64px;height:54px;border-radius:4px;overflow:hidden;background:var(--aboutbg);display:flex;align-items:center;justify-content:center}
.ci-thumb img{width:100%;height:100%;object-fit:cover}
.ci-thumb .shop-ph svg{width:36px}
.ci-mid{flex:1;min-width:0}
.ci-name{font-size:14px;color:var(--label);font-weight:600;line-height:1.25}
.ci-sc{font-size:11px;color:var(--body);opacity:.7;margin-top:3px}
.ci-qty{display:flex;align-items:center;gap:12px;margin-top:10px}
.ci-qty button{appearance:none;width:24px;height:24px;border:1px solid rgba(52,74,127,.3);background:#fff;border-radius:4px;cursor:pointer;color:var(--label);font-size:15px;line-height:1;display:inline-flex;align-items:center;justify-content:center}
.ci-qty button[disabled]{opacity:.35;cursor:not-allowed}
.ci-qty span{font-size:14px;color:var(--body);min-width:14px;text-align:center}
.ci-price{font-size:14px;font-weight:600;color:var(--label);white-space:nowrap}
.cart-foot{padding:20px 26px 26px;border-top:1px solid rgba(52,74,127,.14)}
.cart-sub{display:flex;justify-content:space-between;font-size:16px;color:var(--label);font-weight:600}
.cart-note{font-size:12px;color:var(--body);opacity:.7;margin:8px 0 16px;line-height:1.45}
.cart-foot .btn{width:100%;height:44px;margin-bottom:10px}
.pay-stripe{background:var(--header);border:1px solid var(--header);color:#eaf2fc}
.pay-stripe:hover{background:#16345f;border-color:#16345f}
.pay-paypal{background:#fff;border:1px solid rgba(52,74,127,.35);color:var(--label)}
.pay-paypal:hover{border-color:var(--hblue);color:var(--hblue)}
.cart-secure{font-size:11px;color:var(--body);opacity:.65;text-align:center;margin:6px 0 0;line-height:1.4}
@media(max-width:560px){.cart{width:100%;max-width:100vw}}

/* ----- shop filter + sort controls ----- */
.shop-controls{margin:34px 0 0}
.shop-controls .gal-filter{margin-top:18px}
.shop-controls .gal-filter:first-child{margin-top:0}
.shop-chips{display:flex;gap:10px;flex-wrap:wrap}
.shop-chips .gal-btn{height:var(--btnH);min-height:36px;padding:0 16px;font-size:11px;letter-spacing:.08em}
.shop-tools{display:flex;gap:20px;flex-wrap:wrap;align-items:flex-end;margin-top:24px}
.sel{display:flex;flex-direction:column;gap:7px}
.sel>span{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--label)}
.sel select{appearance:none;-webkit-appearance:none;font-family:inherit;height:42px;min-width:172px;padding:0 38px 0 14px;border:1px solid rgba(52,74,127,.3);border-radius:var(--radius);background:#fff;color:var(--body);font-size:13px;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%23344A7F' stroke-width='1.6'><path d='M1 1.5 6 6.5 11 1.5'/></svg>");background-repeat:no-repeat;background-position:right 14px center}
.sel select:hover{border-color:var(--hblue)}
.sel select:focus{outline:none;border-color:var(--hblue);box-shadow:0 0 0 2px rgba(45,139,194,.15)}
.sel.sort{margin-left:auto}
.shop-clear{appearance:none;border:0;background:none;cursor:pointer;color:var(--label);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;height:42px;padding:0 4px;border-bottom:1px solid transparent}
.shop-clear:hover{color:var(--hblue);border-bottom-color:var(--hblue)}
.shop-count{margin-top:18px;font-size:12px;letter-spacing:.04em;color:var(--body);opacity:.7}
@media(max-width:760px){.sel.sort{margin-left:0}.sel select{min-width:0;width:100%}.sel{flex:1 1 45%}}

/* ----- shop utility row: language flag + currency switch (top right of the shop) ----- */
.shop-utility{display:flex;justify-content:flex-end;align-items:center;gap:16px;margin-bottom:18px}
.shop-utility .flag{border-color:rgba(52,74,127,.35)}
.shop-utility .flag:hover{border-color:var(--hblue);box-shadow:0 0 0 2px rgba(45,139,194,.18)}
.cur{position:relative}
.cur-btn{display:inline-flex;align-items:center;gap:8px;height:30px;padding:0 10px;background:#fff;border:1px solid rgba(52,74,127,.3);border-radius:var(--radius);color:var(--label);font-family:inherit;font-size:12px;font-weight:600;letter-spacing:.08em;cursor:pointer;transition:border-color .2s,box-shadow .2s}
.cur-btn:hover{border-color:var(--hblue)}
.cur-btn .cur-ar{width:13px;height:13px;flex:0 0 auto;transition:transform .2s}
.cur.open .cur-ar{transform:rotate(180deg)}
.cur-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:196px;background:#fff;border:1px solid rgba(52,74,127,.18);border-radius:var(--radius);box-shadow:0 16px 44px rgba(20,40,80,.18);padding:6px;display:none;z-index:40}
.cur.open .cur-menu{display:block}
.cur-opt{display:flex;align-items:center;gap:10px;width:100%;background:none;border:0;border-radius:4px;padding:9px 10px;cursor:pointer;font-family:inherit;text-align:left}
.cur-opt:hover,.cur-opt.on{background:var(--aboutbg)}
.cur-opt .cur-sym{width:30px;font-size:14px;font-weight:700;color:var(--label)}
.cur-opt .cur-nm{width:40px;font-size:12px;font-weight:700;letter-spacing:.06em;color:var(--label)}
.cur-opt.on .cur-nm{color:var(--hblue)}
.cur-opt .cur-full{font-size:12px;color:var(--body);opacity:.85}
@media(max-width:600px){.shop-utility{gap:12px;margin-bottom:14px}}

/* ===================== SHOP v2: tags, sale, detail, notify, banner ===================== */
/* shop-media is now a button (opens detail) */
.shop-card .shop-media{appearance:none;border:0;padding:0;width:100%;display:flex;cursor:pointer;font-family:inherit}
.linklike{appearance:none;border:0;background:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;text-align:left}
.shop-name .linklike:hover{color:var(--label)}

/* product tags (top-left over media) — ONE horizontal row, equal height, never stacked */
.shop-tags{position:absolute;top:12px;left:12px;right:120px;display:flex;flex-flow:row nowrap;gap:6px;align-items:flex-start;z-index:2;pointer-events:none}
.shop-tags .tag{position:static;float:none;box-sizing:border-box;height:20px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--radius);color:#fff;line-height:1;white-space:nowrap;flex:0 0 auto}
.tag.sale{background:#b8472f}
.tag.new{background:var(--hblue)}
.tag.last{background:#9a6a16}
.tag.sale{background:#b8472f}
.tag.new{background:var(--hblue)}
.tag.last{background:#9a6a16}

/* sale price */
.shop-price .was{color:#9a2b2b;opacity:.65;text-decoration:line-through;font-weight:500;font-size:15px;margin-right:8px}
.shop-price .now{color:var(--label)}
.shop-ship{margin:10px 0 0;font-size:12px;color:var(--body);opacity:.75}
.shop-details{appearance:none;border:0;background:none;cursor:pointer;font-family:inherit;color:var(--label);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;padding:12px 0 0;align-self:flex-start}
.shop-details:hover{color:var(--hblue)}
.add.notify{background:transparent;border:1px solid var(--header);color:var(--header)}
.add.notify:hover{background:var(--header);color:#eaf2fc}

/* post-checkout banner */
.shop-flash{position:relative;border-radius:var(--radius);padding:16px 44px 16px 18px;margin:0 0 26px;font-size:14px;line-height:1.5}
.shop-flash.ok{background:rgba(31,122,77,.1);color:#1f7a4d;border:1px solid rgba(31,122,77,.3)}
.shop-flash.info{background:var(--aboutbg);color:var(--label);border:1px solid rgba(52,74,127,.25)}
.flash-x{position:absolute;top:10px;right:12px;appearance:none;border:0;background:none;cursor:pointer;font-size:20px;line-height:1;color:inherit;opacity:.6}
.flash-x:hover{opacity:1}

/* product detail = full page below the top bar */
body.pd-lock{overflow:hidden}
.pd{position:fixed;top:var(--bar);left:0;right:0;bottom:0;z-index:71;background:#fff;overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .25s,transform .25s,visibility .25s}
.pd.open{opacity:1;visibility:visible;transform:none}
.pd-bar{position:sticky;top:0;z-index:5;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);padding:13px var(--gutter);border-bottom:1px solid rgba(52,74,127,.12)}
.pd-back{appearance:none;border:0;background:none;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:8px;color:var(--label);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase}
.pd-back svg{width:18px;height:18px}
.pd-back:hover{color:var(--hblue)}
.pd-inner{margin:0 auto;padding:46px var(--gutter) 80px}
.pd-top{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}

/* detail photo gallery */
.pd-gallery{position:sticky;top:96px}
.pdg-main{position:relative;background:var(--aboutbg);border-radius:var(--radius);aspect-ratio:4/3;overflow:hidden;display:flex;align-items:center;justify-content:center}
.pdg-stage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;cursor:zoom-in}
.pdg-stage img{width:100%;height:100%;object-fit:cover}
.pdg-stage .shop-ph svg{width:150px;color:#9fb1d0;opacity:.55}
.pd-gallery .shop-range{position:absolute;top:14px;right:14px;left:auto;z-index:2}
.pd-gallery .shop-tags{top:14px;left:14px;right:64px}
.pdg-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:42px;height:42px;border-radius:50%;border:0;background:rgba(255,255,255,.9);color:var(--label);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(20,40,80,.16)}
.pdg-arrow svg{width:20px;height:20px}
.pdg-prev{left:14px}.pdg-next{right:14px}
.pdg-arrow:hover{background:#fff;color:var(--hblue)}
.pdg-main.single .pdg-arrow{display:none}
.pdg-zoom{position:absolute;bottom:14px;right:14px;z-index:3;width:40px;height:40px;border-radius:50%;border:0;background:rgba(13,30,61,.78);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}
.pdg-zoom svg{width:20px;height:20px}
.pdg-zoom:hover{background:var(--header)}
.pdg-thumbs{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap}
.pdg-thumb{flex:0 0 auto;width:92px;height:70px;border-radius:4px;overflow:hidden;background:var(--aboutbg);border:2px solid transparent;cursor:pointer;padding:0}
.pdg-thumb img{width:100%;height:100%;object-fit:cover}
.pdg-thumb .shop-ph{display:flex;align-items:center;justify-content:center;height:100%}
.pdg-thumb .shop-ph svg{width:38px;color:#9fb1d0;opacity:.55}
.pdg-thumb.active{border-color:var(--hblue)}

/* detail info column */
.pd-body{display:flex;flex-direction:column;max-width:560px}
.pd-eyebrow{margin:0;font-size:12px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--orange)}
.pd-name{margin:12px 0 0;font-size:30px;font-weight:300;color:var(--hblue);line-height:1.14}
.pd-meta{margin:10px 0 0;font-size:13px;color:var(--body);opacity:.8}
.pd-pricerow{display:flex;align-items:center;gap:14px;margin:20px 0 0}
.pd-pricerow .shop-price{font-size:26px;font-weight:600}
.pd-desc{margin:20px 0 0;font-size:16px;line-height:1.6;color:var(--body);font-weight:500}
.pd-long{margin:14px 0 0;font-size:15px;line-height:1.7;color:var(--body)}
.pd-ship{margin:18px 0 0;font-size:13px;line-height:1.55;color:var(--body)}
.pd-ship strong{color:var(--label)}
.pd-incl{margin:18px 0 0}
.pd-ilab{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--label)}
.pd-incl p{margin:6px 0 0;font-size:13px;line-height:1.55;color:var(--body)}
.pd-body .add{margin-top:24px;width:100%;max-width:340px;height:46px;background:var(--header);border:1px solid var(--header);color:#eaf2fc}
.pd-body .add:hover{background:#16345f}
.pd-returns{margin:16px 0 0;font-size:12px;color:var(--body);opacity:.7;line-height:1.5}
.pd-commission{margin:20px 0 0;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--hblue);text-decoration:none;border-bottom:1px solid rgba(45,139,194,.4);align-self:flex-start;padding-bottom:2px}
.pd-commission:hover{color:var(--label);border-color:var(--label)}
/* notify form (in detail, for out/sold) */
.pd-notify{margin-top:24px;background:var(--aboutbg);border-radius:var(--radius);padding:18px;max-width:420px}
.pd-soldline{margin:0;font-size:14px;font-weight:600;color:var(--label)}
.pd-nlab{display:block;margin:8px 0 12px;font-size:13px;color:var(--body);line-height:1.5}
.pd-nrow{display:flex;gap:10px}
.pd-nrow input{flex:1;height:44px;border:1px solid rgba(52,74,127,.3);border-radius:var(--radius);padding:0 14px;font-family:inherit;font-size:14px;color:var(--body);background:#fff}
.pd-nrow input.err{border-color:#9a2b2b}
.pd-nrow input:focus{outline:none;border-color:var(--hblue)}
.pd-nrow .add{margin-top:0;width:auto;flex:0 0 auto;padding:0 22px;height:44px}
.pd-thanks{margin:0;font-size:14px;color:#1f7a4d;font-weight:600}

/* full-screen zoom overlay */
.pdz{position:fixed;inset:0;z-index:90;background:rgba(6,12,26,.93);display:none;align-items:center;justify-content:center;padding:40px}
.pdz.open{display:flex}
.pdz-stage{max-width:94vw;max-height:90vh;display:flex;align-items:center;justify-content:center}
.pdz-stage img{max-width:94vw;max-height:90vh;object-fit:contain}
.pdz-stage .shop-ph svg{width:min(70vw,520px);color:#e7eefb;opacity:.7}
.pdz-x{position:absolute;top:22px;right:26px;width:42px;height:42px;border-radius:50%;border:0;background:rgba(255,255,255,.14);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}
.pdz-x svg{width:22px;height:22px}
.pdz-x:hover{background:rgba(255,255,255,.26)}

/* detail tabs: about the vessel / about the model */
.pd-tabs{margin:54px 0 0;border-top:1px solid rgba(52,74,127,.14);padding-top:8px}
.pd-tablist{display:flex;gap:36px}
.pd-tab{appearance:none;border:0;background:none;cursor:pointer;font-family:inherit;padding:18px 0;color:var(--body);font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border-bottom:2px solid transparent;margin-bottom:-1px}
.pd-tab:hover{color:var(--hblue)}
.pd-tab.on{color:var(--hblue);border-bottom-color:var(--hblue)}
.pd-panel{display:none;padding:30px 0 0;max-width:880px}
.pd-panel.on{display:block}
.pd-panel p{margin:0 0 14px;font-size:15px;line-height:1.7;color:var(--body)}
.pd-panel p:last-child{margin-bottom:0}
.pd-spec{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 48px;margin:0 0 26px}
.pd-spec .row{display:flex;justify-content:space-between;gap:18px;padding:11px 0;border-bottom:1px solid rgba(52,74,127,.12)}
.pd-spec .k{font-size:13px;color:var(--body);opacity:.75}
.pd-spec .v{font-size:13px;color:var(--label);font-weight:600;text-align:right}
.pd-faq{margin:26px 0 0}
.pd-faqlab{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--label);margin:0 0 6px}
.pd-qa{border-bottom:1px solid rgba(52,74,127,.12)}
.pd-q{appearance:none;border:0;background:none;width:100%;text-align:left;cursor:pointer;font-family:inherit;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 0;font-size:14.5px;font-weight:600;color:var(--label)}
.pd-q .pd-qi{flex:0 0 auto;transition:transform .2s;color:var(--hblue);font-size:18px;line-height:1}
.pd-qa.open .pd-qi{transform:rotate(45deg)}
.pd-a{display:none;padding:0 0 16px;font-size:14px;line-height:1.65;color:var(--body)}
.pd-qa.open .pd-a{display:block}

/* zoom overlay navigation arrows */
.pdz-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:48px;height:48px;border-radius:50%;border:0;background:rgba(255,255,255,.14);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}
.pdz-arrow svg{width:24px;height:24px}
.pdz-prev{left:24px}.pdz-next{right:24px}
.pdz-arrow:hover{background:rgba(255,255,255,.28)}
.pdz.single .pdz-arrow{display:none}

@media(max-width:880px){.pd-top{grid-template-columns:1fr;gap:30px}.pd-inner{padding:30px 32px 60px}.pd-gallery{position:static}.pd-bar{padding:13px 32px}.pd-name{font-size:25px}.pd-spec{grid-template-columns:1fr;gap:0}.pd-tablist{gap:24px}.pdz-prev{left:10px}.pdz-next{right:10px}}

/* ----- shop: fast moving stock line ----- */
.shop-fast{display:inline-flex;align-items:center;gap:10px;margin:16px 0 0;padding:10px 16px;background:var(--aboutbg);border-radius:var(--radius);font-size:14px;color:var(--body);line-height:1.45}
.shop-fast strong{color:var(--label)}
.shop-fast .dot{flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:var(--orange);animation:fastpulse 1.8s infinite}
@keyframes fastpulse{0%{box-shadow:0 0 0 0 rgba(224,138,54,.5)}70%{box-shadow:0 0 0 7px rgba(224,138,54,0)}100%{box-shadow:0 0 0 0 rgba(224,138,54,0)}}

/* ----- home Ready Made banner CTA (reuses .banner) ----- */
.ban-cta{margin:0 0 40px}

/* ----- home Ready Made section: full page, three stacked points, bottom-right CTA ----- */
.shoppage{min-height:var(--page);display:flex;flex-direction:column;justify-content:center}
.ban-intro{max-width:860px;margin:0;color:#c5d4ea;font-size:17px;line-height:1.6}   /* intro under the Ready Made title */
.ban-intro a{color:var(--orange);text-decoration:underline;text-underline-offset:3px}
.ban-intro a:hover{color:#f1ab63}
.ban-points{display:flex;flex-direction:column;gap:30px;max-width:860px;margin:30px 0 0}   /* spacing matched to What We Build: 30px before each sub-title (like .build-sub margin-top); sub-title to text is 12px via .bp-lab */
.rm-banner{display:flex;align-items:center;justify-content:center;width:100%;min-height:525px;margin:30px 0 0;background:rgba(255,255,255,.04);border:1px solid rgba(140,185,225,.3);border-radius:var(--radius);overflow:hidden;position:relative;text-decoration:none}   /* Ready Made banner between the intro and the info points; drop the supplied image in as an <img> inside */
.rm-banner img,.promo img{width:100%;height:100%;object-fit:cover;object-position:left center;display:block}
.rm-banner picture,.promo picture{position:absolute;inset:0;width:100%;height:100%;display:block}
.rm-banner-note{color:#8fb4da;font-size:13px;font-weight:600;letter-spacing:.18em;text-transform:uppercase}

/* ===== Tide, wind & moon in the hero (bottom, aligned with the slogan). Two columns: WIND over TIDE TIMES (left), MOONRISE/SET over MOON PHASE (right) ===== */
.hero-tm{--tmgap:44px;position:absolute;left:var(--gutter);right:var(--gutter);bottom:var(--tmgap);z-index:4;display:flex;justify-content:space-between;align-items:flex-end;gap:24px;pointer-events:none}   /* bottom = the gap from the bottom widget to the page bottom; --tmgap ALSO sets the gap BETWEEN the stacked widgets, so the two spacings are identical */
.hero-tm>.tmw-col{pointer-events:auto;display:flex;flex-direction:column;gap:calc(var(--tmgap) * 2);max-width:230px}   /* each side stacks two widgets; gap is DOUBLE the bottom offset (lower widgets stay at bottom:--tmgap, only the upper ones lift) */
.hero-tm .tmw-col-r{align-items:flex-end}   /* right column hugs the right edge (moonrise/set over moon phase) */
.hero-tm .tmw-col>div{color:var(--ice);text-shadow:0 1px 6px rgba(0,0,0,.6)}
.hero-tm .tmw-moon,.hero-tm .tmw-moonrs{text-align:right}
.hero-tm .tmw-h{font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#fff;margin-bottom:10px}
.hero-tm .tmw-row{display:flex;align-items:center;gap:9px;margin-top:7px}
.hero-tm .tmw-ic{width:20px;height:20px;color:#eaf2fc;flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.hero-tm .tmw-ic svg,.hero-tm .tmw-tideimg{width:20px;height:20px;display:block}
.hero-tm .tmw-lab{font-size:12px;color:#dceaff}
.hero-tm .tmw-tide .tmw-lab,.hero-tm .tmw-wind .tmw-lab{flex:0 0 58px;white-space:nowrap}   /* fixed label width so the wind values (W, 4 mph) left-align under the tide times (the 1 of 16:24) */
.hero-tm .tmw-val{font-size:15px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums;white-space:nowrap}   /* keep e.g. "4 mph" on one line */
.hero-tm .tmw-note{font-size:11px;color:#cfe0f5;margin-top:9px}
.hero-tm .tmw-note strong{color:#fff;font-weight:700}
.hero-tm .tmw-loc{background:rgba(13,30,61,.5);border:1px solid rgba(185,215,245,.6);color:#fff;font:inherit;font-size:11px;padding:4px 9px;border-radius:4px;cursor:pointer}
.hero-tm .tmw-moonrow{display:flex;align-items:center;gap:11px}
.hero-tm .tmw-moon .tmw-moonrow,.hero-tm .tmw-moonrs .tmw-moonrow{flex-direction:row-reverse}
.hero-tm .tmw-moonvis{width:44px;height:44px;flex:0 0 auto}
.hero-tm .tmw-moonvis svg,.hero-tm .tmw-moonimg{width:44px;height:44px;display:block;border-radius:50%}
.hero-tm .tmw-moonimg{filter:drop-shadow(0 0 1.5px rgba(143,180,218,.9))}   /* light rim so a dark new moon reads on the near-black hero (replaces the old SVG stroke) */
.hero-tm .tmw-moontxt{display:flex;flex-direction:column;gap:2px}
.hero-tm .tmw-moon .tmw-moontxt,.hero-tm .tmw-moonrs .tmw-moontxt{align-items:flex-end}
.hero-tm .tmw-moon .tmw-row{gap:0}   /* no inner gap so the phase name/percent right align exactly */
.hero-tm .tmw-moonrs .tmw-row{gap:24px}   /* Rise/Set label to time spacing, matched to the tide widget's label-to-time gap so they do not clash */
.hero-tm .nm{color:#fff;font-size:14px;font-weight:700}
.hero-tm .tmw-sub{font-size:11px;color:#cfe0f5}
@media(max-width:980px){.hero-tm>.tmw-col{max-width:186px}.hero-tm .tmw-moonvis,.hero-tm .tmw-moonvis svg,.hero-tm .tmw-moonvis img{width:38px;height:38px}.hero-tm .tmw-val{font-size:14px}}
@media(max-width:600px){.hero-tm{left:16px;right:16px;gap:12px}.hero-tm>.tmw-col{max-width:47%}.hero-tm .tmw-col>div{text-shadow:0 1px 8px rgba(0,0,0,.78)}.hero-tm .tmw-h{margin-bottom:7px}.hero-flag{margin-right:0;gap:18px}.hero-flag .qu{width:98px;padding:0 10px;white-space:nowrap}}

/* ===== Log in button (contact light variant) + login popup ===== */
.login-btn{width:180px}   /* same size as the Commission button */
.login-light{background:#fff;border-color:rgba(52,74,127,.3);color:var(--label)}
.login-light:hover{background:#fff;border-color:var(--hblue)}
.lgn{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;background:rgba(13,30,61,.7);padding:20px}
.lgn.open{display:flex}
.lgn-card{width:360px;max-width:100%;background:var(--header);border:1px solid rgba(140,185,225,.3);border-radius:8px;padding:30px 28px;position:relative;color:var(--ice);box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lgn-x{position:absolute;top:13px;right:13px;width:30px;height:30px;border:none;background:transparent;color:#8fb4da;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px}
.lgn-x svg{width:20px;height:20px}
.lgn-x:hover{color:var(--ice);background:rgba(140,185,225,.12)}
.lgn-h{font-size:18px;font-weight:700;letter-spacing:.04em;margin-bottom:20px;color:#eaf2fc}
.lgn-form{display:flex;flex-direction:column;gap:16px}
.lgn-field{display:flex;flex-direction:column;gap:7px}
.lgn-field span{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#8fb4da}
.lgn-field input{height:var(--fieldH);background:rgba(255,255,255,.05);border:1px solid rgba(140,185,225,.3);border-radius:var(--radius);color:#fff;padding:0 14px;font-family:inherit;font-size:14px}
.lgn-field input:focus{outline:none;border-color:rgba(185,215,245,.9)}
.lgn-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.lgn-check{display:flex;align-items:center;gap:8px;font-size:13px;color:#c5d4ea;cursor:pointer}
.lgn-forgot{font-size:13px;color:#8fb4da;text-decoration:underline;text-underline-offset:3px}
.lgn-forgot:hover{color:var(--ice)}
.lgn-submit{width:100%;margin-top:6px}
body.lgn-lock{overflow:hidden}

/* ===== Mobile only: all four widgets move to a white banner between hero and About. Two columns: wind/tide (left), moonrise-set/moon (right) ===== */
.tm-banner{display:none}
@media(max-width:600px){
  .hero-tm{display:none}
  .tm-banner{display:flex;flex-direction:column;background:#fff;padding:44px var(--gutter);box-sizing:border-box}   /* widget edge spacing = the site gutter (same as the High Tide range box) */   /* small white band between hero and About (was full screen) */
  .tm-banner-in{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
  .tm-banner .tmw-col{display:flex;flex-direction:column;gap:22px;min-width:0}   /* each side stacks its two widgets */
  .tm-banner .tmw-col-r{align-items:flex-end}
  .tm-banner .tmw-moon,.tm-banner .tmw-moonrs{text-align:right}
  .tm-banner .tmw-h{font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#1C345D;margin-bottom:9px}   /* white is invisible on the white banner, so dark navy here */
  .tm-banner .tmw-row{display:flex;align-items:center;gap:8px;margin-top:6px}
  .tm-banner .tmw-ic{width:20px;height:20px;color:var(--label);flex:0 0 auto;display:flex;align-items:center;justify-content:center}
  .tm-banner .tmw-ic svg,.tm-banner .tmw-tideimg{width:20px;height:20px;display:block}
  .tm-banner .tmw-lab{font-size:12px;color:var(--body);white-space:nowrap}
  .tm-banner .tmw-tide .tmw-lab,.tm-banner .tmw-wind .tmw-lab{flex:1}   /* narrow banner: keep values to the edge (avoid overflow) */
  .tm-banner .tmw-val{font-size:15px;font-weight:700;color:var(--label);font-variant-numeric:tabular-nums;white-space:nowrap}
  .tm-banner .tmw-note{font-size:11px;color:var(--label);opacity:.8;margin-top:8px}
  .tm-banner .tmw-note strong{color:var(--hblue);font-weight:700}
  .tm-banner .tmw-loc{background:transparent;border:1px solid rgba(52,74,127,.4);color:var(--label);font:inherit;font-size:11px;padding:4px 9px;border-radius:4px;cursor:pointer}
  .tm-banner .tmw-moonrow{display:flex;align-items:center;gap:8px}   /* tightened with the wider gutter so the labels still fit */
  .tm-banner .tmw-moon .tmw-moonrow,.tm-banner .tmw-moonrs .tmw-moonrow{flex-direction:row-reverse}
  .tm-banner .tmw-moonvis{width:42px;height:42px;flex:0 0 auto}
  .tm-banner .tmw-moonvis svg,.tm-banner .tmw-moonimg{width:42px;height:42px;display:block;border-radius:50%}
  .tm-banner .tmw-moonimg{filter:drop-shadow(0 0 1.2px rgba(40,70,120,.55))}   /* dark rim so a light full moon reads on the white banner */
  .tm-banner .tmw-moontxt{display:flex;flex-direction:column;gap:2px}
  .tm-banner .tmw-moon .tmw-moontxt,.tm-banner .tmw-moonrs .tmw-moontxt{align-items:flex-end}
  .tm-banner .tmw-moon .tmw-row{gap:0}
  .tm-banner .tmw-moonrs .tmw-row{gap:6px}   /* Moonrise/Moonset to time spacing, tightened so the full labels fit the half-column at the wider gutter */
  .tm-banner .nm{color:var(--label);font-size:13px;font-weight:700}
  .tm-banner .tmw-sub{font-size:11px;color:var(--body);opacity:.75}
}
.ban-point .bp-lab{color:#8fb4da;font-size:15px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-bottom:12px}   /* size matched to .build-sub ("Eyes on every step") */
.ban-point p{color:#c5d4ea;font-size:16px;line-height:1.65;margin:0}   /* size + line-height matched to .process .pnote */
.shoppage .ban-strip{margin-top:40px}   /* tightened gap from the info points to the photos */
.shop-cta{align-self:flex-end;margin-top:40px}   /* pinned to the bottom so the band stays one full page */   /* width + height inherited from .btn.commission, so identical to the Commission button; aligned to the right gutter */
@media(max-width:860px){.ban-points{max-width:640px}}

/* ----- shop page: info points (fast stock / worldwide delivery) ----- */
.shop-points{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:20px 0 0;max-width:900px}
.shop-point{background:var(--aboutbg);border-radius:var(--radius);padding:16px 18px}
.shop-point .sp-lab{display:flex;align-items:center;gap:8px;color:var(--label);font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}   /* size + tracking matched to gallery .gal-flab */
.shop-point .sp-lab .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);flex:0 0 auto;animation:fastpulse 1.8s infinite}
.shop-point p{margin:0;font-size:13px;line-height:1.6;color:var(--body)}   /* size + line-height matched to gallery .gal-hint */
@media(max-width:620px){.shop-points{grid-template-columns:1fr}}

/* ----- shop page: promotions banner (hero band, sits before the grid; shows one priority promo) ----- */
.promo{margin:40px 0 100px;min-height:525px;background:var(--header);border-radius:var(--radius);box-sizing:border-box;position:relative;overflow:hidden;display:block;text-decoration:none}   /* navy band: 100px side gutters (1240 at the frame) x 525px; 100px gap below to the filters */
.shop-head{display:flex;align-items:stretch;justify-content:space-between;gap:50px}
.shop-head-main{flex:0 1 auto;max-width:760px}
.shop-head-main .eyebrow{margin-top:0}
.shop-head-logo{flex:0 0 auto;position:relative;width:240px}
.shop-head-logo img{position:absolute;top:0;right:0;height:100%;width:auto;display:block}   /* top aligns to Ready Made, bottom to start a quote, right edge at the 100px gutter */
@media(max-width:760px){.shop-head{flex-direction:column;gap:24px}.shop-head-logo{position:static;width:auto;height:130px}.shop-head-logo img{position:static;height:100%}}
.shop-search{position:relative;width:calc((100% - var(--fieldgap)) / 2);margin:0 auto 100px}   /* centered; width spans the middle four vessel-type buttons: left edge = Historic & Classics (3rd), right edge = Naval & Military (6th). 100px above from the banner, 100px below to the filters */
.shop-search input{width:100%;height:var(--fieldH);box-sizing:border-box;border:1px solid var(--stroke);border-radius:var(--radius);padding:0 18px 0 48px;font-size:15px;color:var(--body);background:#fff;font-family:inherit}
.shop-search input::placeholder{color:#9aa6b2}
.shop-search input:focus{outline:none;border-color:var(--hblue)}
.shop-search-ic{position:absolute;left:18px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--label);pointer-events:none}
.shop-points-foot{margin-top:50px}   /* info-points relocated to the bottom, before the footer */

/* ==========================================================================
   TABLET (<= 980px)
   ========================================================================== */
@media(max-width:980px){
  .edge-grid{grid-template-columns:1fr 1fr}   /* tablets: 2 columns; phones use a swipe carousel below */
}

/* mobile carousel wrapper + arrows (arrows hidden until the phone breakpoint) */
.mcar{position:relative}
.m-arrow{display:none}

/* ==========================================================================
   MOBILE PHONE (<= 600px)
   ========================================================================== */
@media(max-width:600px){
  :root{--gutter:28px}

  /* header: hamburger + centred logo only (Commission lives in the menu) */
  .logo img{height:28px}
  .hr-right{gap:10px}
  .topbar{padding:0 var(--gutter)}                                                  /* respect the site gutter (28px) on both edges: menu button 28px from left, Commission 28px from right */
  .topbar .commission{display:inline-flex;min-width:0;width:98px;padding:0 10px;height:26px;font-size:10px;letter-spacing:.04em}   /* longer on mobile too; still right-anchored */   /* kept in the bar (Dean), compacted to fit */
  .hr-right:has(.cart-btn){gap:10px}                                       /* shop page: tighten cart + Commission so both fit */
  .menu{left:12px;right:12px}
  .menu a{padding:13px 22px;letter-spacing:.16em}

  /* hero: phones load the dedicated portrait image (assets/hero-mobile.png) and fill the screen */
  .hero-img{object-fit:cover}
  .hero-slogan{display:none}   /* mobile hero image carries its own composition */

  /* type: 16px base, 26px headings, 14px supporting */
  .display,.h2,.etitle,.qh,section.quote .qh{font-size:26px;line-height:1.18;margin-top:20px;margin-bottom:20px}
  .about-summary .display{margin-bottom:14px}
  .ranges .display{margin-bottom:20px}
  .eyebrow{font-size:11px}
  .edge-card .n,.proc-card .num,.enum{font-size:44px}
  .lead,.about-summary .lead,.rintro,.qsub,.range-box .r-body,.ban-note,.ban-intro,.pintro,.pnote,.intro,.build-lead p,.edge-sec .elead,.edge-sec .intro{font-size:16px}
  .c-val{font-size:18px;word-break:break-word}

  /* section frames: 56px top/bottom, sides from --gutter */
  .edge,.ranges,.build,.process,section.quote,.contact,.banner,.about-summary,.edge-sec,.wrap{padding-top:56px;padding-bottom:56px}

  /* ---- BOX CAROUSELS (two rows, horizontal swipe) ---- */
  .edge-grid,.build-grid,.cards{
    display:grid;grid-auto-flow:column;grid-template-columns:none;
    grid-template-rows:repeat(2,auto);grid-auto-rows:auto;gap:16px 14px;max-width:none;
    overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    overscroll-behavior-x:contain;scrollbar-width:none;padding-bottom:4px}
  .edge-grid::-webkit-scrollbar,.build-grid::-webkit-scrollbar,.cards::-webkit-scrollbar{display:none}
  .edge-grid,.cards{grid-auto-columns:100%}        /* Edge + About: 2 stacked, full content width, no peek */
  .build-grid{grid-auto-columns:calc(50% - 7px);gap:14px 14px}  /* What We Build: 4 per screen (2 x 2), no peek */
  .edge-card,.build-card,.card{scroll-snap-align:start}
  .card{padding:24px 22px}

  /* arrows on the sides, animated like the desktop ones */
  .m-arrow,.proc-arrow{display:flex;align-items:center;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);
    width:38px;height:38px;border-radius:50%;border:none;cursor:pointer;z-index:6;color:var(--orange);
    background:rgba(255,255,255,.94);box-shadow:0 3px 14px rgba(20,40,80,.22)}
  .m-arrow svg,.proc-arrow svg{width:22px;height:22px;display:block}
  .m-prev,.proc-prev{left:-12px;right:auto}
  .m-next,.proc-next{right:-12px;left:auto}
  .m-prev svg,.proc-prev svg{animation:nudgeL 1.9s ease-in-out infinite}
  .m-next svg,.proc-next svg{animation:nudgeR 1.9s ease-in-out infinite}

  /* Two Tides */
  .ranges-grid{gap:24px}

  /* photo strips */
  .ban-item{width:64vw}

  /* payment: stacked steps on phones, hide the one-line bar */
  .pay{flex-direction:column;align-items:stretch;justify-content:flex-start;padding:18px 20px;text-align:left;gap:0}
  .pay .pl{margin-bottom:14px}
  .pay .pv{display:none}
  .pay-steps{display:flex}

  /* About cards: title, then the badge line, then the description */
  .card-body{flex-direction:column;margin-top:16px;gap:14px}
  .card-badge{flex:0 0 auto}
  .card-badge .num{font-size:40px}

  /* Bespoke Build Process: two stacked per screen + arrows */
  .proc-track{display:grid;grid-auto-flow:column;grid-template-rows:repeat(2,auto);grid-auto-columns:100%;gap:16px 14px}
  .proc-card{flex-basis:auto;min-height:0;scroll-snap-align:start}

  /* ---- Request a Quote ---- */
  section.quote{justify-content:flex-start}
  .qsteps{max-width:none;display:block;border-radius:0}
  .qstep{display:none}
  .qstep.active{display:flex;width:100%;border-radius:0}
  .qstep.active .ql{display:inline}
  .qrow{flex-direction:column;gap:18px}
  .qacct,.qcontact,.qrange,.qdates{flex-direction:column;width:100%;gap:14px}
  .qphone{gap:12px}
  .qrow-up{align-items:stretch}
  .qfield input[type=file]{width:100%}
  .qfilelist{width:100%}

  /* ---- Contact ---- */
  .contact-grid{grid-template-columns:1fr;gap:34px}
  .c-aside{padding:24px 20px}
  .cform .cf-row{flex-direction:column;gap:18px}
  .cf-check,.qcheck{white-space:normal;align-items:flex-start}
  .c-val,.c-sub{overflow-wrap:break-word}

  /* ---- Footer: stacked links, centred logo ---- */
  .ft-top{flex-direction:column;gap:30px;align-items:center;text-align:center}
  .ft-links{flex-direction:column;flex-wrap:nowrap;gap:14px;align-items:center}
  .ft-book{align-items:center}
  .ft-privacy{text-align:center}
  .ft-top{gap:30px}
  .ft-base{margin-top:30px}
  .ft-logo{justify-content:center}

  /* ---- Shop: centred logo, full-width search, 2 products per row ---- */
  .shop-head{flex-direction:column;align-items:center;text-align:center;gap:22px}
  .shop-head-logo{position:static;width:auto;height:84px;order:-1}
  .shop-head-logo img{position:static;height:100%;margin:0 auto}
  .shop-search{width:100%;margin:28px 0}
  .shop-grid{grid-template-columns:1fr 1fr;gap:18px 14px}
  .promo{min-height:300px;margin:24px 0 40px}

  /* ---- 2026-06-18 mobile-only adjustments (desktop untouched) ---- */
  #ourwork{min-height:var(--page);display:flex;flex-direction:column;justify-content:center}   /* Our Work: full screen, content centred, spacing grows to fill any phone height */
  .rm-banner{aspect-ratio:auto;min-height:300px}                                                /* home Ready Made banner matches the shop promo band (300px tall) */
  .founder>p:last-child{margin-bottom:0}                                                        /* trailing founder paragraph: drop the extra 16px so the gap to the separator matches the other sections */
  .gr-tag{display:block}                                                                        /* range filter buttons read as 4 lines: name / (range) / desc line 1 / desc line 2 */
}

/* ==========================================================================
   GALLERY: full screen photo viewer (home #ourwork) + Visit gallery CTA
   ========================================================================== */
#ourwork .ban-item{cursor:zoom-in;padding:0;font:inherit;color:inherit;-webkit-appearance:none;appearance:none;position:relative;background-size:cover;background-position:center;border:1.5px solid #8fb4da;transition:box-shadow .3s}   /* light blue outline; same 1.5px on the small strip photo and the big full screen photo */
.gallery-cta-row{display:flex;justify-content:flex-end;margin-top:40px}   /* mirrors Shop now: 40px below the strip; the section's 100px bottom padding sits below the button */

.glb{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:0;background:rgba(13,30,61,0);opacity:0;visibility:hidden;pointer-events:none;transition:background .42s ease,opacity .28s ease,visibility 0s linear .42s}
.glb.open{background:rgba(13,30,61,.7);opacity:1;visibility:visible;pointer-events:auto;transition:background .42s ease,opacity .2s ease}   /* same blue tint and transparency as the top bar */
.glb-stage{display:flex;flex-direction:column;align-items:center;gap:16px}
.glb-figure{border-radius:var(--radius);overflow:hidden;border:1.5px solid #8fb4da;box-shadow:0 30px 80px rgba(0,0,0,.5);background:var(--header);line-height:0}
.glb-figure img{display:block;width:auto;height:auto;max-width:calc(100vw - (2 * var(--gutter)));max-height:calc(100vh - 96px);object-fit:contain;border-radius:var(--radius)}   /* full image width = page width less the side margins */
.glb-ph{width:calc(100vw - (2 * var(--gutter)));max-width:calc(100vw - (2 * var(--gutter)));aspect-ratio:4/3;max-height:calc(100vh - 96px);background:var(--aboutbg);display:flex;align-items:center;justify-content:center;border-radius:var(--radius)}
.glb-ph svg{width:148px;height:auto;color:#9fb1d0;opacity:.55}
.glb-cap{color:#cfe0f5;font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;text-align:center}
.glb-cap .r{color:var(--orange)}
.glb-cap .r.low{color:var(--hblue)}
.glb-cap .glb-title{display:block;color:#eaf2fc;font-size:16px;letter-spacing:.1em;font-weight:700;margin-bottom:6px}
.glb-cap .glb-meta{display:block}
.glb-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;background:transparent;border:none;color:var(--ice);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.85;transition:color .2s,opacity .2s}
.glb-nav:hover{color:#fff;opacity:1}
.glb-nav svg{width:30px;height:30px;display:block;filter:drop-shadow(0 1px 3px rgba(0,0,0,.55))}
.glb-prev{left:clamp(10px,2.2vw,30px)}
.glb-next{right:clamp(10px,2.2vw,30px)}
.glb-close{position:fixed;top:20px;right:clamp(14px,2.4vw,32px);width:46px;height:46px;background:transparent;border:none;color:var(--ice);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.85;transition:color .2s,opacity .2s;z-index:2}
.glb-close:hover{color:#fff;opacity:1}
.glb-close svg{width:26px;height:26px;display:block;filter:drop-shadow(0 1px 3px rgba(0,0,0,.55))}
body.glb-lock{overflow:hidden}
@media(max-width:560px){.glb-nav{width:42px;height:42px}.glb-prev{left:8px}.glb-next{right:8px}.glb-figure img,.glb-ph{max-height:78vh}}

/* ===== Floating WhatsApp "Chat with a human" button (injected by assets/whatsapp.js on every page) ===== */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:300;display:flex;align-items:center;height:58px;width:58px;border-radius:29px;background:#fff;color:var(--orange);text-decoration:none;box-shadow:0 6px 22px rgba(0,0,0,.3);overflow:hidden;white-space:nowrap;transition:width .3s cubic-bezier(.4,0,.2,1),box-shadow .2s}   /* inverted: white background, ORANGE logo + label (currentColor = --orange); no outline, the shadow keeps it defined */   /* collapsed = a 58px circle so it never overlaps the hero widgets; expands left on hover to reveal the label */
.wa-float .wa-ico{flex:0 0 58px;width:58px;height:58px;display:flex;align-items:center;justify-content:center}
.wa-float .wa-ico svg{width:31px;height:31px;display:block}
.wa-float .wa-txt{font-size:14px;font-weight:600;letter-spacing:.01em;opacity:0;transition:opacity .18s ease .06s}
.wa-float:hover,.wa-float:focus-visible{width:218px;box-shadow:0 10px 30px rgba(0,0,0,.34)}
.wa-float:hover .wa-txt,.wa-float:focus-visible .wa-txt{opacity:1;padding-right:22px}
.wa-float:focus-visible{outline:2px solid #fff;outline-offset:2px}
@media(max-width:600px){.wa-float{right:28px;bottom:28px;width:54px;height:54px}.wa-float .wa-ico{flex-basis:54px;width:54px;height:54px}}
