/* Heenan Engraving — design system. Palettes/accents driven by body[data-mood][data-accent]. */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
[hidden] { display:none !important; }
body {
  margin: 0;
  font-family: 'Inter', system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
}
:root { --display: 'Fraunces','Times New Roman',serif; --body: 'Inter',system-ui,sans-serif; --mono: 'JetBrains Mono',ui-monospace,monospace; --max: 1240px; }

body[data-mood="ivory"] { --bg:#F4EDE3; --bgAlt:#EBE1D1; --plate:#14100C; --ink:#1F1A15; --inkSoft:#6A5B4C; --rule:#D9CBB6; --glow:rgba(255,235,205,.22); }
body[data-mood="onyx"]  { --bg:#0D0B09; --bgAlt:#151210; --plate:#050403; --ink:#F0E5D3; --inkSoft:#9E8E78; --rule:#2A231C; --glow:rgba(255,225,185,.14); }
body[data-mood="bone"]  { --bg:#F7F5F0; --bgAlt:#EDEAE2; --plate:#0D0B09; --ink:#1A1916; --inkSoft:#6B6860; --rule:#DAD6CC; --glow:rgba(255,240,220,.20); }

body[data-accent="copper"]    { --accent:#8A6A4A; }
body[data-accent="garnet"]    { --accent:#7A2E2A; }
body[data-accent="verdigris"] { --accent:#3F6159; }

.boot { padding: 120px 32px; font-family: var(--mono); font-size: 12px; letter-spacing:.2em; text-transform:uppercase; color: var(--inkSoft); }
.container { max-width: var(--max); margin: 0 auto; padding: 0 32px; }
section { border-top: 1px solid var(--rule); }
img { max-width: 100%; display: block; }

/* Kicker */
.kicker { display:flex; align-items:center; gap:14px; color:var(--inkSoft); font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; }
.kicker.center { justify-content:center; }
.kicker .bar { width:28px; height:1px; background:var(--accent); display:inline-block; }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:10px; padding:14px 22px; font-family:var(--body); font-size:13px; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; border:1px solid; transition:all 180ms ease; text-decoration:none; }
.btn.primary { background:var(--ink); color:var(--bg); border-color:var(--ink); }
.btn.primary .arr { opacity:.6; }
.btn.secondary { background:transparent; color:var(--ink); border-color:var(--rule); }
.btn:hover { opacity:.88; }

/* Nav */
header.nav { border-bottom:1px solid var(--rule); background:var(--bg); position:sticky; top:0; z-index:10; backdrop-filter:blur(6px); }
.nav-row { display:flex; align-items:center; justify-content:space-between; padding:18px 0; }
.wordmark { text-decoration:none; color:var(--ink); display:flex; align-items:baseline; gap:10px; }
.wordmark .w1 { font-family:var(--display); font-size:22px; font-style:italic; font-weight:400; letter-spacing:-.01em; }
.wordmark .w2 { font-family:var(--mono); font-size:10px; color:var(--inkSoft); letter-spacing:.22em; text-transform:uppercase; }
.nav-links { display:flex; gap:32px; }
.nav-links a { font-family:var(--body); font-size:13px; color:var(--ink); text-decoration:none; letter-spacing:.02em; }
.nav-right { display:flex; align-items:center; gap:14px; }
.open-now { font-family:var(--mono); font-size:10px; color:var(--inkSoft); letter-spacing:.2em; text-transform:uppercase; display:flex; align-items:center; }
.open-now .dot { display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--accent); margin-right:8px; }
.nav-cart { font-family:var(--body); font-size:13px; padding:10px 14px; border:1px solid var(--rule); background:transparent; color:var(--ink); cursor:pointer; letter-spacing:.02em; }
.nav-cart span { display:inline-block; min-width:20px; margin-left:8px; padding:1px 7px; border-radius:999px; background:var(--bgAlt); color:var(--ink); font-family:var(--mono); font-size:10px; text-align:center; }
.nav-cart.has-items { border-color:var(--ink); }
.nav-cart.has-items span { background:var(--ink); color:var(--bg); }
.nav-cta { font-family:var(--body); font-size:13px; padding:10px 14px; border:1px solid var(--ink); color:var(--ink); text-decoration:none; }

/* Display heading */
.display { margin:0; font-family:var(--display); font-weight:300; letter-spacing:-.025em; line-height:.98; color:var(--ink); font-variation-settings:"opsz" 144; }
.display span { display:block; }
.display .it { font-style:italic; }

/* Hero */
.hero { padding:56px 0 100px; background:var(--bg); }
.hero-grid { display:grid; grid-template-columns:auto 1fr auto; column-gap:40px; align-items:start; }
.hero-marker { font-family:var(--mono); font-size:10px; letter-spacing:.24em; color:var(--inkSoft); text-transform:uppercase; writing-mode:vertical-rl; transform:rotate(180deg); margin-top:6px; }
.hero h1 { font-size:136px; }
.hero-body { display:grid; grid-template-columns:1.1fr 1fr; gap:48px; margin-top:48px; align-items:start; }
.hero-sub { margin:0; font-family:var(--body); font-size:18px; line-height:1.55; color:var(--inkSoft); }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.hero-aside { margin-top:32px; font-family:var(--mono); font-size:11px; color:var(--inkSoft); letter-spacing:.12em; text-transform:uppercase; }
.hero-plate { width:360px; }
.hero.split .hero-grid, .hero.typeled .hero-grid { display:block; }
.hero.split h1, .hero.typeled h1 { font-size:104px; }
.hero.typeled { text-align:center; }
.hero.typeled .hero-sub { margin:40px auto 0; max-width:620px; }
.hero.typeled .hero-actions { justify-content:center; }
.stats { margin-top:96px; border-top:1px solid var(--rule); padding-top:32px; display:grid; grid-template-columns:repeat(4,1fr); gap:40px; }
.stat .k { font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--inkSoft); }
.stat .n { margin-top:8px; font-family:var(--display); font-size:44px; font-weight:300; color:var(--ink); letter-spacing:-.02em; line-height:1; font-variation-settings:"opsz" 144; }
.stat .l { margin-top:6px; font-family:var(--body); font-size:13px; color:var(--inkSoft); }

/* Section header */
.sec { padding:120px 0; background:var(--bg); }
.sec.alt { background:var(--bgAlt); }
.sec-head { display:grid; grid-template-columns:auto 1fr; gap:40px; align-items:start; margin-bottom:72px; }
.sec-num { font-family:var(--mono); font-size:11px; letter-spacing:.22em; color:var(--inkSoft); text-transform:uppercase; padding-top:14px; }
.sec-title { margin:20px 0 0; font-family:var(--display); font-weight:300; font-size:72px; line-height:1; letter-spacing:-.02em; color:var(--ink); font-variation-settings:"opsz" 144; }
.sec-title span { display:block; }
.sec-title .it { font-style:italic; }
.sec-lede { margin-top:22px; max-width:560px; font-family:var(--body); font-size:16px; line-height:1.55; color:var(--inkSoft); }

/* Process / grids */
.grid4 { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; background:var(--rule); border:1px solid var(--rule); }
.grid3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--rule); border:1px solid var(--rule); }
.cell { background:var(--bg); padding:32px 28px 40px; min-height:240px; }
.sec.alt .cell { background:var(--bgAlt); }
.cell .cn { font-family:var(--display); font-style:italic; font-size:44px; color:var(--accent); font-weight:300; line-height:1; font-variation-settings:"opsz" 144; }
.cell .ct { margin-top:22px; font-family:var(--display); font-size:22px; color:var(--ink); font-weight:400; }
.cell .cb { margin-top:14px; font-family:var(--body); font-size:14px; line-height:1.55; color:var(--inkSoft); }

/* Shapes */
.shape { display:flex; flex-direction:column; background:var(--bgAlt); padding:36px 30px 32px; text-align:left; border:none; min-height:220px; color:var(--ink); width:100%; cursor:default; transition:background 200ms; }
.shape:hover { background:var(--bg); }
.shape-top { display:flex; justify-content:space-between; align-items:flex-start; }
.shape .feat { font-family:var(--mono); font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); border:1px solid var(--accent); padding:3px 8px; }
.shape .plate { margin-bottom:20px; aspect-ratio:1/1; }
.shape .plate + .nm { margin-top:0; }
.shape-media-link + .nm { margin-top:0; }
.shape-media-link { position:relative; display:block; color:inherit; text-decoration:none; }
.shape-media-link span { position:absolute; right:12px; bottom:32px; z-index:2; padding:8px 10px; background:var(--ink); color:var(--bg); font-family:var(--body); font-size:11px; letter-spacing:.06em; text-transform:uppercase; opacity:0; transform:translateY(6px); transition:opacity 180ms ease, transform 180ms ease; pointer-events:none; }
.shape-media-link:hover span, .shape-media-link:focus-visible span { opacity:1; transform:translateY(0); }
/* Product photos: fill the frame, minimal crop (renders are ~square) */
.shape .plate img { object-fit:cover; object-position:center; mix-blend-mode:normal; filter:none; padding:0; }
.shape .nm { margin-top:36px; font-family:var(--display); font-size:28px; color:var(--ink); font-weight:400; }
.shape .meta { margin-top:6px; font-family:var(--mono); font-size:11px; color:var(--inkSoft); letter-spacing:.1em; text-transform:uppercase; }
.shape .nt { margin-top:16px; font-family:var(--body); font-size:14px; line-height:1.55; color:var(--inkSoft); }

/* Product plate */
.plate { margin:0; background:var(--plate); position:relative; overflow:hidden; border:1px solid var(--rule); aspect-ratio:4/5; }
.plate .glow { position:absolute; inset:0; background:radial-gradient(ellipse at 50% 40%, var(--glow) 0%, transparent 55%); pointer-events:none; }
.plate img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; mix-blend-mode:screen; filter:contrast(1.05); }
.plate.empty::after { content:"Photo coming soon"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:rgba(240,229,211,.4); font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; }
.plate figcaption { position:absolute; left:16px; bottom:14px; color:rgba(240,229,211,.72); font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; }

/* Gallery */
.gal { display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:24px; align-items:end; }
.gal .g1 { transform:translateY(-28px); }
.gal .g2 { transform:translateY(14px); }
.gal.grid { grid-template-columns:repeat(3,1fr); gap:20px 24px; align-items:start; }
.gal-item { display:block; color:inherit; text-decoration:none; }
.gal-item .plate { transition:transform 180ms ease, border-color 180ms ease; }
.gal-item:hover .plate, .gal-item:focus-visible .plate { transform:translateY(-4px); border-color:var(--ink); }
.gal-cap { margin-top:14px; font-family:var(--mono); font-size:10px; color:var(--inkSoft); letter-spacing:.18em; text-transform:uppercase; display:flex; justify-content:space-between; }
.gal-cap strong { color:var(--ink); font:inherit; white-space:nowrap; margin-left:12px; }
.gal-cta { margin-top:64px; display:flex; justify-content:center; }

/* Crystal editor */
.crystal-editor { background:var(--bgAlt); }
.editor-head { margin-bottom:48px; }
.editor-grid { display:grid; grid-template-columns:minmax(280px, 420px) 1fr; gap:64px; align-items:start; }
.editor-panel { background:var(--bg); border:1px solid var(--rule); padding:28px; position:sticky; top:92px; }
.editor-steps { display:grid; grid-template-columns:repeat(3, 1fr); margin-bottom:18px; border:1px solid var(--rule); }
.editor-steps span { padding:10px 8px; border-right:1px solid var(--rule); color:var(--inkSoft); font-family:var(--mono); font-size:9px; letter-spacing:.14em; text-transform:uppercase; text-align:center; }
.editor-steps span:last-child { border-right:0; }
.editor-tabs { display:grid; grid-template-columns:1fr 1fr; border:1px solid var(--rule); margin-bottom:26px; }
.editor-tabs button, .editor-align button { min-width:0; padding:12px 10px; background:transparent; color:var(--ink); border:0; border-right:1px solid var(--rule); font-family:var(--body); font-size:12px; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; }
.editor-tabs button:last-child, .editor-align button:last-child { border-right:0; }
.editor-tabs button.is-active, .editor-align button.is-active { background:var(--ink); color:var(--bg); }
.editor-block { margin-bottom:24px; }
.editor-label { margin-bottom:10px; font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--inkSoft); }
.editor-shapes { max-height:340px; overflow:auto; display:grid; gap:8px; padding-right:4px; }
.editor-shape { width:100%; display:grid; grid-template-columns:48px 1fr; gap:12px; align-items:center; padding:11px; border:1px solid var(--rule); background:transparent; color:var(--ink); text-align:left; cursor:pointer; }
.editor-shape.is-active { border-color:var(--ink); background:var(--bgAlt); }
.editor-shape-glyph { width:48px; height:48px; display:grid; place-items:center; background:var(--bgAlt); border:1px solid var(--rule); overflow:hidden; }
.editor-shape-glyph svg { width:30px; height:30px; }
.editor-shape b { display:block; font-family:var(--body); font-size:13px; font-weight:500; line-height:1.25; }
.editor-shape em { display:block; margin-top:3px; font-family:var(--mono); font-size:9px; font-style:normal; letter-spacing:.12em; text-transform:uppercase; color:var(--inkSoft); line-height:1.35; }
.editor-pane { display:grid; gap:14px; }
.editor-tools { display:grid; gap:12px; }
.editor-tool-row { display:grid; grid-template-columns:1fr 1fr 1fr; border:1px solid var(--rule); }
.editor-tool-row button { min-width:0; padding:11px 8px; background:transparent; color:var(--ink); border:0; border-right:1px solid var(--rule); font-family:var(--body); font-size:12px; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; }
.editor-tool-row button:last-child { border-right:0; }
.editor-tool-row button.is-active { background:var(--ink); color:var(--bg); }
.upload-field, .editor-field { display:grid; gap:8px; font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--inkSoft); }
.upload-field { position:relative; border:1px solid var(--rule); padding:15px; cursor:pointer; }
.upload-field input[type=file] { position:absolute; inset:0; opacity:0; cursor:pointer; }
.upload-field strong { display:inline-flex; width:max-content; padding:10px 13px; background:var(--ink); color:var(--bg); font-family:var(--body); font-size:12px; letter-spacing:.06em; text-transform:uppercase; font-weight:500; }
.upload-field em { font-family:var(--body); font-size:12px; font-style:normal; color:var(--inkSoft); letter-spacing:0; text-transform:none; overflow-wrap:anywhere; }
.editor-field input[type=text] { width:100%; padding:11px 12px; border:1px solid var(--rule); background:var(--bg); color:var(--ink); font-family:var(--body); font-size:15px; letter-spacing:0; text-transform:none; }
.editor-field input[type=range] { width:100%; accent-color:var(--accent); }
.editor-align { display:grid; grid-template-columns:repeat(3, 1fr); border:1px solid var(--rule); }
.editor-enquire { width:100%; justify-content:center; margin-top:22px; border:0; }
.editor-cart-status { min-height:18px; margin-top:10px; font-family:var(--body); font-size:13px; color:#8a2a2a; }
.editor-stage { min-height:640px; position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:56px 42px; border:1px solid var(--rule); overflow:hidden; background:linear-gradient(145deg, rgba(255,255,255,.32), transparent 42%), var(--plate); }
.editor-stage::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 50% 35%, rgba(255,255,255,.16), transparent 36%); pointer-events:none; }
.editor-selected { position:absolute; top:22px; left:22px; right:22px; z-index:3; display:flex; justify-content:space-between; gap:18px; color:rgba(240,229,211,.82); font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; }
.editor-selected em { font-style:normal; color:rgba(240,229,211,.56); text-align:right; }
.crystal-preview { --editor-text-size:36px; position:relative; z-index:2; width:min(100%, 440px); aspect-ratio:4/5; overflow:hidden; border:1px solid rgba(255,255,255,.34); background:linear-gradient(135deg, rgba(255,255,255,.44), rgba(255,255,255,.08) 28%, rgba(255,255,255,.18) 62%, rgba(255,255,255,.05)), rgba(185,205,215,.24); box-shadow:0 34px 90px rgba(0,0,0,.36), inset 0 0 35px rgba(255,255,255,.12); }
.crystal-preview::before { content:""; position:absolute; inset:0; background:linear-gradient(110deg, transparent 0 28%, rgba(255,255,255,.34) 31%, transparent 38% 100%); opacity:.55; z-index:4; pointer-events:none; }
.crystal-preview::after { content:""; position:absolute; inset:12px; border:1px solid rgba(255,255,255,.24); z-index:5; pointer-events:none; }
.crystal-preview[data-preview-shape="rectangle"] { border-radius:4px; }
.crystal-preview[data-preview-shape="circle"] { width:min(100%, 430px); aspect-ratio:1; border-radius:50%; }
.crystal-preview[data-preview-shape="diamond"] { width:min(100%, 430px); aspect-ratio:1; clip-path:polygon(50% 0, 100% 48%, 52% 100%, 0 52%); }
.crystal-preview[data-preview-shape="cube"] { width:min(100%, 430px); aspect-ratio:1; clip-path:polygon(14% 0, 100% 0, 86% 100%, 0 100%); }
.crystal-preview[data-preview-shape="heart"] { width:min(100%, 430px); aspect-ratio:1; clip-path:polygon(50% 92%, 15% 58%, 5% 35%, 9% 16%, 25% 5%, 40% 9%, 50% 24%, 60% 9%, 75% 5%, 91% 16%, 95% 35%, 85% 58%); }
.crystal-preview[data-preview-shape="tower"] { width:min(100%, 350px); aspect-ratio:3/5; clip-path:polygon(22% 0, 78% 0, 92% 100%, 8% 100%); }
.crystal-preview[data-preview-shape="iceberg"] { width:min(100%, 430px); aspect-ratio:1; clip-path:polygon(50% 0, 91% 26%, 82% 100%, 18% 100%, 8% 28%); }
.crystal-preview[data-preview-shape="pentagon"] { width:min(100%, 430px); aspect-ratio:1; clip-path:polygon(50% 0, 96% 36%, 78% 100%, 22% 100%, 4% 36%); }
.crystal-preview[data-preview-shape="arch"] { width:min(100%, 410px); aspect-ratio:4/5; border-radius:48% 48% 4px 4px / 28% 28% 4px 4px; }
.crystal-preview[data-preview-shape="dome"] { width:min(100%, 360px); aspect-ratio:3/4; border-radius:50% 50% 5px 5px / 30% 30% 5px 5px; }
.crystal-preview[data-preview-shape="lamp"] { width:min(100%, 340px); aspect-ratio:3/5; border-radius:46% 8px 8px 8px / 20% 8px 8px 8px; }
.crystal-preview[data-preview-shape="candle"] { width:min(100%, 360px); aspect-ratio:3/4; clip-path:polygon(16% 0, 84% 0, 92% 100%, 8% 100%); }
.crystal-preview[data-preview-shape="notched"] { width:min(100%, 420px); aspect-ratio:4/5; clip-path:polygon(10% 0, 94% 0, 94% 88%, 78% 88%, 72% 100%, 10% 100%, 0 86%, 0 12%); }
.crystal-preview[data-preview-shape="oval"] { width:min(100%, 470px); aspect-ratio:1.34; border-radius:50%; }
.crystal-preview[data-preview-shape="halfmoon"] { width:min(100%, 500px); aspect-ratio:1.85; border-radius:50% 50% 5px 5px / 100% 100% 5px 5px; }
.crystal-preview[data-preview-shape="landscape"] { width:min(100%, 520px); aspect-ratio:5/3; border-radius:4px; }
.crystal-depth { position:absolute; inset:9%; border:1px solid rgba(255,255,255,.18); transform:translate(10px, 12px); z-index:1; }
.engraving-layer { position:absolute; inset:17% 17% 20%; z-index:2; display:flex; flex-direction:column; align-items:center; justify-content:center; overflow:hidden; color:rgba(245,248,248,.76); }
.engraving-layer[data-photo-tool="move"] { cursor:grab; }
.engraving-layer[data-photo-tool="erase"] { cursor:crosshair; }
.engraving-layer::after { content:""; position:absolute; inset:0; background-image:radial-gradient(rgba(255,255,255,.2) .35px, transparent .65px); background-size:2px 2px; opacity:.12; mix-blend-mode:screen; pointer-events:none; }
.engraving-photo { width:100%; height:100%; object-fit:cover; opacity:.74; filter:grayscale(1) contrast(1.12) brightness(1.05); mix-blend-mode:screen; image-rendering:auto; touch-action:none; }
.engraving-empty { border:1px dashed rgba(255,255,255,.35); padding:12px 14px; font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:rgba(240,229,211,.62); }
.text-engraving { gap:12px; text-align:center; padding:8px; }
.engraving-logo { max-width:72%; max-height:92px; object-fit:contain; opacity:.72; filter:grayscale(1) contrast(1.16) brightness(1.05); mix-blend-mode:screen; image-rendering:auto; }
.engraving-main { max-width:100%; font-family:var(--display); font-size:var(--editor-text-size); line-height:1.05; color:rgba(245,248,248,.82); overflow-wrap:anywhere; }
.engraving-sub { max-width:100%; font-family:var(--body); font-size:14px; line-height:1.35; letter-spacing:.08em; text-transform:uppercase; color:rgba(245,248,248,.62); overflow-wrap:anywhere; }
.editor-note { position:relative; z-index:2; margin-top:24px; color:rgba(240,229,211,.56); font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; text-align:center; line-height:1.6; }

/* Stories */
.story { background:var(--bgAlt); padding:40px 32px 32px; display:flex; flex-direction:column; justify-content:space-between; min-height:320px; }
.story .qm { font-family:var(--display); font-style:italic; font-size:44px; color:var(--accent); font-weight:300; line-height:.6; }
.story .q { margin-top:14px; font-family:var(--display); font-size:22px; line-height:1.35; color:var(--ink); font-weight:400; }
.story .who { margin-top:32px; border-top:1px solid var(--rule); padding-top:16px; display:flex; justify-content:space-between; align-items:baseline; }
.story .a { font-family:var(--body); font-size:14px; color:var(--ink); }
.story .loc, .story .sh { margin-top:2px; font-family:var(--mono); font-size:10px; letter-spacing:.18em; color:var(--inkSoft); text-transform:uppercase; }

/* Visit */
.visit-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.visit h2 { font-size:72px; }
.visit-lede { margin-top:24px; max-width:460px; font-family:var(--body); font-size:17px; line-height:1.55; color:var(--inkSoft); }
.visit dl { margin-top:40px; display:grid; grid-template-columns:auto 1fr; row-gap:14px; column-gap:36px; font-family:var(--body); font-size:15px; }
.visit dt { font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--inkSoft); text-transform:uppercase; padding-top:3px; }
.visit dd { margin:0; color:var(--ink); }
.visit-actions { margin-top:40px; display:flex; gap:12px; }
.map { position:relative; aspect-ratio:1/1.1; background:var(--bgAlt); border:1px solid var(--rule); overflow:hidden; }
.map iframe { position:absolute; inset:0; width:100%; height:100%; border:0; }
.map .lbl { position:absolute; left:16px; top:16px; padding:6px 10px; background:var(--bg); border:1px solid var(--rule); font-family:var(--mono); font-size:10px; letter-spacing:.2em; color:var(--inkSoft); text-transform:uppercase; pointer-events:none; }

/* Footer */
footer { padding:80px 0 48px; background:var(--bgAlt); border-top:1px solid var(--rule); color:var(--ink); }
.foot-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; align-items:start; }
.foot-mark { font-family:var(--display); font-style:italic; font-size:52px; font-weight:300; line-height:.9; letter-spacing:-.02em; font-variation-settings:"opsz" 144; }
.foot-tag { margin-top:16px; font-family:var(--mono); font-size:11px; letter-spacing:.22em; color:var(--inkSoft); text-transform:uppercase; }
.foot-col .fl { font-family:var(--mono); font-size:10px; letter-spacing:.2em; color:var(--inkSoft); text-transform:uppercase; margin-bottom:16px; }
.foot-col ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px; }
.foot-col li { font-family:var(--body); font-size:14px; color:var(--ink); }
.foot-legal { margin-top:64px; padding-top:24px; border-top:1px solid var(--rule); display:flex; justify-content:space-between; font-family:var(--mono); font-size:10px; letter-spacing:.18em; color:var(--inkSoft); text-transform:uppercase; }

/* Contact slide-over */
.overlay { position:fixed; inset:0; background:rgba(0,0,0,.45); display:none; opacity:0; transition:opacity 300ms; z-index:50; }
.contact-panel { position:fixed; top:0; right:0; height:100%; width:420px; max-width:90vw; background:var(--bg); color:var(--ink); border-left:1px solid var(--rule); padding:48px 40px; transform:translateX(100%); transition:transform 320ms ease; z-index:51; overflow-y:auto; }
.contact-close { position:absolute; right:24px; top:24px; background:none; border:none; color:var(--inkSoft); cursor:pointer; font-size:16px; }
.contact-kicker { font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--inkSoft); }
.contact-h { font-family:var(--display); font-weight:300; font-size:34px; margin:8px 0 8px; }
.contact-sub { font-family:var(--body); font-size:14px; color:var(--inkSoft); line-height:1.55; margin:0 0 28px; }
#contact-form { display:flex; flex-direction:column; gap:16px; }
#contact-form label { display:flex; flex-direction:column; gap:6px; font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--inkSoft); }
#contact-form input, #contact-form textarea { font-family:var(--body); font-size:15px; padding:11px 12px; border:1px solid var(--rule); background:var(--bg); color:var(--ink); border-radius:0; }
#contact-form button { margin-top:8px; padding:14px; background:var(--ink); color:var(--bg); border:none; font-family:var(--body); font-size:13px; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; }
.contact-status { font-family:var(--body); font-size:13px; margin:4px 0 0; }

/* Cart */
.cart-fab { position:fixed; right:24px; bottom:24px; z-index:49; background:var(--ink); color:var(--bg); border:none; padding:14px 20px; font-family:var(--body); font-size:13px; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; box-shadow:0 10px 30px rgba(0,0,0,.25); }
.cart-fab span { display:inline-block; margin-left:8px; background:var(--accent); border-radius:999px; padding:1px 8px; }
.cart-panel { width:460px; }
.shape-buy { margin-top:auto; padding-top:22px; display:flex; gap:10px; align-items:center; }
.shape-buy button { display:inline-flex; align-items:center; justify-content:center; min-height:40px; padding:11px 16px; background:var(--ink); color:var(--bg); border:none; font-family:var(--body); font-size:12px; line-height:1.15; letter-spacing:.05em; text-transform:uppercase; text-align:center; cursor:pointer; white-space:nowrap; }
.shape-buy .enq { background:transparent; color:var(--ink); border:1px solid var(--rule); }
.shape-buy .soon { background:transparent; color:var(--inkSoft); border:1px solid var(--rule); cursor:default; }
.shape-price { font-family:var(--mono); font-size:13px; color:var(--ink); }
.ci { border:1px solid var(--rule); padding:14px; margin-bottom:14px; }
.ci-top { display:flex; justify-content:space-between; font-family:var(--body); font-size:15px; }
.ci-top b { font-weight:600; }
.ci-row { display:flex; align-items:center; gap:10px; margin-top:10px; }
.ci-row label { font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--inkSoft); }
.ci input[type=number] { width:64px; padding:7px; border:1px solid var(--rule); background:var(--bg); color:var(--ink); }
.ci textarea { width:100%; margin-top:10px; padding:9px; border:1px solid var(--rule); background:var(--bg); color:var(--ink); font-family:var(--body); font-size:14px; }
.ci .thumb { width:54px; height:54px; object-fit:cover; background:var(--plate); border:1px solid var(--rule); }
.ci .text-thumb { display:grid; place-items:center; color:var(--bg); font-family:var(--mono); font-size:11px; letter-spacing:.12em; }
.ci .up { padding:8px 12px; background:var(--ink); color:var(--bg); border:none; font-size:12px; cursor:pointer; }
.ci .rm { background:none; border:none; color:#8a2a2a; font-size:12px; cursor:pointer; text-decoration:underline; }
.ci .need { color:#8a2a2a; font-size:12px; font-family:var(--body); margin-top:6px; }
.ci .need.ok { color:var(--inkSoft); }
.cart-sum { display:flex; justify-content:space-between; font-family:var(--body); font-size:15px; margin:8px 0; }
.cart-sum.total { font-weight:600; font-size:18px; border-top:1px solid var(--rule); padding-top:12px; margin-top:12px; }
.cart-panel h4 { font-family:var(--display); font-weight:400; font-size:20px; margin:22px 0 10px; }
.delivery-opt { display:flex; gap:10px; align-items:flex-start; border:1px solid var(--rule); padding:12px; margin-bottom:8px; cursor:pointer; font-family:var(--body); font-size:14px; }
.delivery-opt input { width:auto; margin-top:3px; }
.delivery-opt span { display:grid; gap:3px; flex:1; }
.delivery-opt b { font-weight:500; color:var(--ink); }
.delivery-opt em { font-style:normal; color:var(--inkSoft); font-size:12px; line-height:1.4; }
.delivery-opt strong { font-weight:500; color:var(--accent); font-size:12px; }
.editor-shape.is-unavailable { opacity:.62; }
.editor-shape.is-unavailable b::after { content:"Coming soon"; display:inline-block; margin-left:8px; font-family:var(--mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:#8a2a2a; }
.co-field { display:flex; flex-direction:column; gap:5px; margin-bottom:12px; font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--inkSoft); }
.co-field input, .co-field textarea { padding:11px 12px; border:1px solid var(--rule); background:var(--bg); color:var(--ink); font-family:var(--body); font-size:15px; letter-spacing:0; text-transform:none; }
.cart-cta { width:100%; margin-top:14px; padding:15px; background:var(--ink); color:var(--bg); border:none; font-family:var(--body); font-size:14px; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; }
.cart-cta[disabled] { opacity:.5; cursor:default; }
.cart-empty { font-family:var(--body); color:var(--inkSoft); padding:30px 0; }
.cart-err { color:#8a2a2a; font-family:var(--body); font-size:13px; margin-top:10px; }
.cart-back { background:none; border:none; color:var(--inkSoft); font-size:13px; cursor:pointer; text-decoration:underline; padding:0; margin-bottom:14px; font-family:var(--body); }
.order-banner { position:fixed; top:0; left:0; right:0; z-index:60; padding:14px 20px; text-align:center; font-family:var(--body); font-size:14px; color:#fff; background:#2d5a3d; }
.order-banner.bad { background:#8a2a2a; }
.order-banner button { margin-left:14px; background:rgba(255,255,255,.2); color:#fff; border:none; padding:5px 10px; cursor:pointer; }

@media (max-width: 960px) {
  .hero-grid { grid-template-columns:1fr; } .hero-marker { display:none; }
  .hero h1, .hero.split h1, .hero.typeled h1 { font-size:60px; }
  .hero-body, .visit-grid { grid-template-columns:1fr; gap:32px; }
  .hero-plate { width:100%; }
  .grid4, .grid3, .gal, .foot-grid { grid-template-columns:1fr; }
  .gal .g1, .gal .g2 { transform:none; }
  .editor-grid { grid-template-columns:1fr; gap:28px; }
  .editor-panel { position:static; padding:22px; }
  .editor-stage { min-height:520px; padding:72px 18px 34px; }
  .editor-selected { flex-direction:column; gap:6px; }
  .editor-selected em { text-align:left; }
  .crystal-preview { width:min(100%, 340px); }
  .sec-title, .visit h2 { font-size:48px; }
  .stats { grid-template-columns:1fr 1fr; }
  .nav-links { display:none; }
  .sec { padding:72px 0; }
}
