/* ==========================================================================
   ELLORA WOOD — Design System
   Palette derived from the catalog photography: warm walnut & tan wood
   tones with a soft glass-blue accent lifted from window light in the
   product shots.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,500;1,9..144,600&family=Inter:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

:root{
  /* ---- Palette (extracted from catalog imagery) ---- */
  --cream:        #F4EEE4;
  --paper:        #FBF8F2;
  --ink:          #241C13;
  --walnut:       #2B2115;
  --walnut-soft:  #3D3021;
  --wood-mid:     #8B7355;
  --wood-tan:     #C9AD8C;
  --wood-tan-lt:  #E4D5BF;
  --glass-blue:   #93AEBC;
  --glass-blue-deep:#5C7986;

  --line: rgba(43,33,21,0.12);
  --line-lt: rgba(255,255,255,0.35);

  /* glass */
  --glass-bg: rgba(251,248,242,0.55);
  --glass-bg-dark: rgba(43,33,21,0.42);
  --glass-border: rgba(255,255,255,0.45);
  --glass-blur: 18px;

  /* type */
  --f-display: 'Fraunces', Georgia, serif;
  --f-body: 'Inter', -apple-system, sans-serif;
  --f-mono: 'Space Mono', monospace;

  --container: 1280px;
  --radius: 20px;
  --radius-sm: 12px;

  --ease: cubic-bezier(.22,.88,.28,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background: var(--cream);
  color: var(--ink);
  font-family: var(--f-body);
  -webkit-font-smoothing: antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

/* subtle grain texture, keeps the glass from feeling sterile */
.grain{
  position:fixed; inset:0; z-index:2; pointer-events:none; opacity:0.035; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

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

/* ---- eyebrow / labels ---- */
.eyebrow{
  font-family:var(--f-mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--wood-mid); display:flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:''; width:26px; height:1px; background:var(--wood-mid); }

/* ---- headings ---- */
h1,h2,h3{ font-family:var(--f-display); font-weight:600; margin:0; line-height:1.02; letter-spacing:-0.01em; }
.h-xl{ font-size: clamp(48px, 8vw, 108px); }
.h-lg{ font-size: clamp(34px, 5vw, 58px); }
.h-md{ font-size: clamp(24px, 3vw, 34px); }
em{ font-style:italic; color:var(--wood-mid); }

/* ==========================================================================
   NAV
   ========================================================================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:18px 0;
  transition: background .4s var(--ease), backdrop-filter .4s var(--ease), padding .3s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(140%);
  border-bottom:1px solid var(--line);
  padding:12px 0;
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; }
.logo{ height:30px; }
.nav-links{ display:flex; gap:36px; align-items:center; font-size:14px; font-weight:500; }
.nav-links a{ position:relative; padding:4px 0; }
.nav-links a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--wood-mid);
  transition:width .3s var(--ease);
}
.nav-links a:hover::after{ width:100%; }
.nav-cta{
  background:var(--walnut); color:var(--paper); padding:11px 22px; border-radius:100px; font-size:13px; font-weight:600;
  letter-spacing:.02em; transition: transform .3s var(--ease), background .3s;
}
.nav-cta:hover{ background:var(--wood-mid); transform:translateY(-2px); }
.nav-toggle{
  display:none; flex-direction:column; justify-content:center; gap:5px; width:38px; height:38px;
  background:transparent; border:none; cursor:pointer; padding:0;
}
.nav-toggle span{ display:block; width:100%; height:2px; background:var(--ink); border-radius:2px; transition:transform .3s var(--ease), opacity .3s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:flex-end;
  overflow:hidden; padding-bottom:110px;
}
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media .layer{
  position:absolute; inset:0; background-size:cover; background-position:center; opacity:0;
  animation: heroFade 16s infinite;
}
.hero-media .layer:nth-child(1){ animation-delay:0s; }
.hero-media .layer:nth-child(2){ animation-delay:4s; }
.hero-media .layer:nth-child(3){ animation-delay:8s; }
.hero-media .layer:nth-child(4){ animation-delay:12s; }
@keyframes heroFade{
  0%{ opacity:0; transform:scale(1.06); }
  6%{ opacity:1; transform:scale(1.0); }
  25%{ opacity:1; transform:scale(1.0);}
  31%{ opacity:0; transform:scale(1.0);}
  100%{ opacity:0; }
}
.hero-scrim{
  position:absolute; inset:0; z-index:1;
  background: linear-gradient(180deg, rgba(43,33,21,.15) 0%, rgba(43,33,21,.35) 55%, rgba(20,15,9,.86) 100%);
}
.hero-content{ position:relative; z-index:2; width:100%; }
.hero-eyebrow{ color:var(--wood-tan-lt); margin-bottom:22px; opacity:0; animation: rise .9s var(--ease) .3s forwards; }
.hero-eyebrow::before{ background:var(--wood-tan-lt); }
.hero h1{ color:var(--paper); opacity:0; animation: rise 1s var(--ease) .5s forwards; }
.hero p.lead{
  color:var(--wood-tan-lt); font-size:18px; max-width:480px; margin-top:26px; line-height:1.6;
  opacity:0; animation: rise 1s var(--ease) .75s forwards;
}
.hero-actions{ display:flex; gap:16px; margin-top:40px; opacity:0; animation: rise 1s var(--ease) .95s forwards; }
@keyframes rise{ from{ opacity:0; transform:translateY(28px); } to{ opacity:1; transform:translateY(0); } }

.btn{
  display:inline-flex; align-items:center; gap:10px; padding:16px 30px; border-radius:100px;
  font-size:14px; font-weight:600; letter-spacing:.02em; transition: transform .35s var(--ease), background .3s, color .3s;
  cursor:pointer; border:none;
}
.btn-primary{ background:var(--paper); color:var(--walnut); }
.btn-primary:hover{ transform:translateY(-3px); background:var(--wood-tan-lt); }
.btn-ghost{
  background:var(--glass-bg-dark); color:var(--paper); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.25);
}
.btn-ghost:hover{ background:rgba(255,255,255,.14); transform:translateY(-3px); }

.hero-scroll{
  position:absolute; right:32px; bottom:36px; z-index:2; writing-mode:vertical-rl;
  color:var(--wood-tan-lt); font-family:var(--f-mono); font-size:11px; letter-spacing:.2em;
  display:flex; align-items:center; gap:14px; opacity:.8;
}
.hero-scroll .line{ width:1px; height:60px; background:linear-gradient(var(--wood-tan-lt), transparent); animation:scrollLine 2.2s ease-in-out infinite; }
@keyframes scrollLine{ 0%,100%{ transform:scaleY(1); opacity:.9;} 50%{ transform:scaleY(.4); opacity:.4; } }

/* ==========================================================================
   SECTION SHELL
   ========================================================================== */
section{ padding:120px 0; position:relative; }
.section-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:40px; margin-bottom:64px; flex-wrap:wrap; }
.section-head p{ max-width:420px; color:var(--wood-mid); font-size:15px; line-height:1.6; margin-top:16px; }

/* ==========================================================================
   CATEGORY TILES (glass, 3D tilt)
   ========================================================================== */
.cat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.cat-card{
  position:relative; border-radius:var(--radius); overflow:hidden; height:460px;
  transform-style:preserve-3d; will-change:transform;
  transition: box-shadow .4s var(--ease);
  box-shadow: 0 20px 50px -25px rgba(43,33,21,.5);
}
.cat-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transform:scale(1.08); transition:transform .8s var(--ease); }
.cat-card:hover img{ transform:scale(1.16); }
.cat-card .scrim{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,15,9,0) 30%, rgba(20,15,9,.88) 100%); }
.cat-card .glass-tag{
  position:absolute; top:24px; left:24px; padding:8px 16px; border-radius:100px;
  background:var(--glass-bg); backdrop-filter:blur(10px); border:1px solid var(--glass-border);
  font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--walnut);
}
.cat-card .cat-info{ position:absolute; left:28px; right:28px; bottom:28px; z-index:2; transform:translateZ(40px); }
.cat-card .cat-info h3{ color:var(--paper); font-size:30px; margin-bottom:8px; }
.cat-card .cat-info span{ color:var(--wood-tan-lt); font-size:13px; font-family:var(--f-mono); }
.cat-card .arrow{
  position:absolute; right:24px; bottom:26px; width:44px; height:44px; border-radius:50%;
  background:var(--paper); display:flex; align-items:center; justify-content:center; z-index:3;
  transform: translateY(10px) scale(.8); opacity:0; transition: all .4s var(--ease);
}
.cat-card:hover .arrow{ transform:translateY(0) scale(1); opacity:1; }

/* ==========================================================================
   PRODUCT GRID + FILTER
   ========================================================================== */
.filter-bar{
  display:flex; gap:10px; flex-wrap:wrap; margin-bottom:48px; position:sticky; top:88px; z-index:20;
  background:var(--glass-bg); backdrop-filter:blur(var(--glass-blur)); border:1px solid var(--glass-border);
  padding:10px; border-radius:100px; width:fit-content;
}
.filter-pill{
  padding:11px 22px; border-radius:100px; font-size:13px; font-weight:600; cursor:pointer;
  color:var(--wood-mid); transition: all .3s var(--ease); background:transparent; border:none;
  font-family:var(--f-body); white-space:nowrap;
}
.filter-pill.active{ background:var(--walnut); color:var(--paper); }
.filter-pill:hover:not(.active){ background:rgba(43,33,21,.08); }

.product-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; }
.product-card{
  border-radius:var(--radius); overflow:hidden; background:var(--paper);
  border:1px solid var(--line); position:relative;
  opacity:0; transform:translateY(36px);
  transition: transform .5s var(--ease), box-shadow .4s var(--ease);
}
.product-card.in-view{ opacity:1; transform:translateY(0); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.product-card:hover{ box-shadow:0 24px 50px -22px rgba(43,33,21,.4); }
.product-card .thumb{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.product-card .thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.product-card:hover .thumb img{ transform:scale(1.08); }
.product-card .thumb .code-tag{
  position:absolute; top:14px; left:14px; background:var(--glass-bg); backdrop-filter:blur(8px);
  border:1px solid var(--glass-border); padding:5px 12px; border-radius:100px; font-family:var(--f-mono); font-size:11px;
}
.product-card .body{ padding:20px 22px 24px; }
.product-card .body .cat{ font-family:var(--f-mono); font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--wood-mid); }
.product-card .body h4{ font-family:var(--f-display); font-size:22px; margin-top:8px; font-weight:600; }
.product-card .body .dim-preview{ margin-top:10px; font-size:12.5px; color:var(--wood-mid); line-height:1.5; }
.product-card .view-link{
  margin-top:16px; display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600;
  color:var(--walnut);
}
.product-card .view-link svg{ transition:transform .3s var(--ease); }
.product-card:hover .view-link svg{ transform:translateX(4px); }

.empty-state{ display:none; text-align:center; padding:80px 0; color:var(--wood-mid); font-family:var(--f-mono); }

/* ==========================================================================
   BRAND / STORY (dark glass section)
   ========================================================================== */
.story{
  background: var(--walnut); color:var(--paper); border-radius:32px; margin:0 32px; overflow:hidden; position:relative;
  padding:100px 60px;
}
.story::before{
  content:''; position:absolute; inset:0; opacity:.5;
  background: radial-gradient(circle at 15% 20%, rgba(147,174,188,.25), transparent 45%),
              radial-gradient(circle at 85% 80%, rgba(201,173,140,.2), transparent 50%);
}
.story-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; position:relative; z-index:1; align-items:center; }
.story h2{ color:var(--paper); }
.story p{ color:var(--wood-tan-lt); line-height:1.75; margin-top:24px; font-size:16px; max-width:460px; }
.stat-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:28px; margin-top:40px; }
.stat{ border-top:1px solid rgba(255,255,255,.18); padding-top:16px; }
.stat b{ font-family:var(--f-display); font-size:40px; display:block; font-weight:600; }
.stat span{ font-size:13px; color:var(--wood-tan-lt); font-family:var(--f-mono); }
.story-visual{ position:relative; }
.story-visual .glass-frame{
  border-radius:24px; overflow:hidden; position:relative; transform-style:preserve-3d; will-change:transform;
  box-shadow:0 30px 70px -30px rgba(0,0,0,.6);
}
.story-visual img{ width:100%; height:520px; object-fit:cover; }
.story-visual .float-card{
  position:absolute; bottom:-24px; left:-24px; background:var(--glass-bg); backdrop-filter:blur(var(--glass-blur));
  border:1px solid var(--glass-border); border-radius:16px; padding:18px 22px; color:var(--ink);
  animation: float 5s ease-in-out infinite;
}
.float-card b{ font-family:var(--f-display); font-size:20px; display:block; }
.float-card span{ font-size:11px; font-family:var(--f-mono); color:var(--wood-mid); }
@keyframes float{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-14px);} }

/* ==========================================================================
   FOOTER
   ========================================================================== */
footer{ padding:80px 0 36px; }
.footer-top{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; padding-bottom:60px; border-bottom:1px solid var(--line); }
.footer-brand p{ max-width:320px; color:var(--wood-mid); margin-top:18px; font-size:14px; line-height:1.6; }
.footer-cols{ display:flex; gap:80px; }
.footer-col h5{ font-family:var(--f-mono); font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--wood-mid); margin-bottom:18px; }
.footer-col a{ display:block; font-size:14px; margin-bottom:12px; color:var(--ink); transition:color .25s; }
.footer-col a:hover{ color:var(--wood-mid); }
.footer-bottom{ display:flex; justify-content:space-between; padding-top:28px; font-size:12px; color:var(--wood-mid); flex-wrap:wrap; gap:12px; }

/* ==========================================================================
   PRODUCT DETAIL PAGE
   ========================================================================== */
.p-hero{ padding:150px 0 0; }
.breadcrumb{ display:flex; align-items:center; gap:8px; font-family:var(--f-mono); font-size:12px; color:var(--wood-mid); margin-bottom:40px; }
.breadcrumb a:hover{ color:var(--ink); }
.p-layout{ display:grid; grid-template-columns:1.3fr 1fr; gap:56px; align-items:start; }
.p-media{
  position:relative; border-radius:28px; overflow:hidden; perspective:1000px;
}
.p-media .tilt-wrap{ transform-style:preserve-3d; will-change:transform; transition:transform .1s ease-out; border-radius:28px; overflow:hidden;}
.p-media img{ width:100%; height:auto; display:block; }
.p-media .glare{
  position:absolute; inset:0; pointer-events:none; opacity:0; transition:opacity .4s;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.35), transparent 45%);
}
.p-media:hover .glare{ opacity:1; }
.p-badge{
  position:absolute; top:20px; left:20px; z-index:2; background:var(--glass-bg); backdrop-filter:blur(10px);
  border:1px solid var(--glass-border); padding:8px 16px; border-radius:100px; font-family:var(--f-mono); font-size:12px;
}
.p-info .eyebrow{ margin-bottom:20px; }
.p-info h1{ font-size:clamp(36px,4.2vw,54px); }
.p-info .code{ font-family:var(--f-mono); color:var(--wood-mid); font-size:14px; margin-top:14px; }

.spec-panel{
  margin-top:36px; background:var(--glass-bg); backdrop-filter:blur(var(--glass-blur)); border:1px solid var(--glass-border);
  border-radius:20px; padding:28px;
}
.spec-panel h3{ font-family:var(--f-mono); font-size:12px; text-transform:uppercase; letter-spacing:.12em; color:var(--wood-mid); font-weight:700; margin-bottom:18px; }
.spec-row{ display:flex; justify-content:space-between; align-items:baseline; padding:14px 0; border-bottom:1px solid var(--line); gap:16px; }
.spec-row:last-child{ border-bottom:none; }
.spec-row .label{ font-size:14px; color:var(--wood-mid); }
.spec-row .value{ font-family:var(--f-mono); font-size:15px; font-weight:700; text-align:right; }
.custom-note{ display:flex; align-items:center; gap:14px; }
.custom-note b{ font-family:var(--f-display); font-size:22px; }
.custom-note span{ font-size:13px; color:var(--wood-mid); }

.p-actions{ display:flex; gap:14px; margin-top:32px; }

.related-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:28px; }

/* ==========================================================================
   REVEAL / UTILITIES
   ========================================================================== */
.reveal{ opacity:0; transform:translateY(30px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in-view{ opacity:1; transform:translateY(0); }
.stagger .reveal:nth-child(1){ transition-delay:.05s; }
.stagger .reveal:nth-child(2){ transition-delay:.15s; }
.stagger .reveal:nth-child(3){ transition-delay:.25s; }
.stagger .reveal:nth-child(4){ transition-delay:.35s; }

/* ==========================================================================
   LANGUAGE SWITCHER
   ========================================================================== */
.lang-switcher{ position:relative; }
.lang-toggle{
  display:flex; align-items:center; gap:6px; background:rgba(43,33,21,.06); border:1px solid var(--line);
  padding:9px 14px; border-radius:100px; font-size:12px; font-weight:700; font-family:var(--f-mono);
  color:var(--ink); cursor:pointer; letter-spacing:.05em;
}
.lang-toggle svg{ width:10px; height:10px; transition:transform .3s var(--ease); }
.lang-switcher.open .lang-toggle svg{ transform:rotate(180deg); }
.lang-dropdown{
  position:absolute; top:calc(100% + 10px); right:0; min-width:160px; background:var(--paper);
  border:1px solid var(--line); border-radius:14px; box-shadow:0 20px 45px -20px rgba(43,33,21,.35);
  padding:8px; display:none; flex-direction:column; gap:2px; z-index:200;
}
.lang-switcher.open .lang-dropdown{ display:flex; }
.lang-option{
  text-align:left; background:none; border:none; padding:10px 12px; border-radius:9px; font-size:13.5px;
  color:var(--ink); cursor:pointer; font-family:var(--f-body);
}
.lang-option:hover{ background:rgba(43,33,21,.06); }
.lang-option.active{ background:var(--walnut); color:var(--paper); font-weight:600; }
[dir="rtl"] .lang-dropdown{ right:auto; left:0; text-align:right; }

/* ==========================================================================
   RTL (Arabic) LAYOUT ADJUSTMENTS
   ========================================================================== */
body.rtl{ direction:rtl; }
body.rtl .eyebrow::before{ margin-left:10px; margin-right:0; }
body.rtl .nav-links{ flex-direction:row-reverse; }
body.rtl .breadcrumb{ flex-direction:row-reverse; justify-content:flex-end; }
body.rtl .p-layout,
body.rtl .story-grid{ direction:rtl; }
body.rtl .spec-row{ flex-direction:row-reverse; }
body.rtl .card-view svg,
body.rtl .view-link svg{ transform:scaleX(-1); }
body.rtl .footer-top{ flex-direction:row-reverse; }
body.rtl .hero-scroll{ right:auto; left:32px; writing-mode:vertical-rl; }
body.rtl .cat-card .cat-info,
body.rtl .float-card{ text-align:right; }
body.rtl .whatsapp-order svg{ transform:scaleX(-1); }

/* ==========================================================================
   WHATSAPP ORDER BUTTON
   ========================================================================== */
.whatsapp-order{
  display:inline-flex; align-items:center; gap:10px; background:#25D366; color:#fff; border:none;
  padding:16px 26px; border-radius:100px; font-size:14px; font-weight:700; cursor:pointer;
  transition: transform .3s var(--ease), background .3s; font-family:var(--f-body);
}
.whatsapp-order:hover{ background:#1EBE5A; transform:translateY(-3px); }
.whatsapp-order svg{ width:19px; height:19px; flex-shrink:0; }

@media (max-width: 980px){
  .cat-grid{ grid-template-columns:1fr; }
  .product-grid{ grid-template-columns:repeat(2,1fr); }
  .story-grid{ grid-template-columns:1fr; }
  .p-layout{ grid-template-columns:1fr; }
  .related-strip{ grid-template-columns:repeat(2,1fr); }
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; }
  .nav-links.open{
    display:flex; flex-direction:column; gap:0; position:fixed; inset:0; top:0; padding:110px 32px 40px;
    background:var(--cream); backdrop-filter:blur(var(--glass-blur)); z-index:99;
  }
  .nav-links.open a{ font-size:22px; font-family:var(--f-display); padding:16px 0; border-bottom:1px solid var(--line); }
  .footer-top{ flex-direction:column; }
}
@media (max-width: 600px){
  .container{ padding:0 20px; }
  .product-grid{ grid-template-columns:1fr; }
  .story{ margin:0 16px; padding:60px 26px; border-radius:22px; }
  section{ padding:80px 0; }
  .stat-grid{ grid-template-columns:1fr 1fr; }
  .related-strip{ grid-template-columns:1fr 1fr; }
}

/* ==========================================================================
   LEGAL DOCUMENT PAGES
   ========================================================================== */
.legal-doc{ max-width:760px; margin:0 auto; padding:150px 32px 120px; }
.legal-doc .eyebrow{ margin-bottom:18px; }
.legal-doc h1{ font-size:clamp(30px,4vw,44px); margin-bottom:8px; }
.legal-doc .updated{ font-family:var(--f-mono); font-size:12.5px; color:var(--wood-mid); margin-bottom:36px; display:block; }
.legal-doc .lang-notice{
  background:var(--glass-bg); border:1px solid var(--glass-border); backdrop-filter:blur(var(--glass-blur));
  border-radius:14px; padding:16px 20px; font-size:13.5px; color:var(--wood-mid); margin-bottom:40px; line-height:1.6;
}
.legal-doc h2{ font-size:22px; margin-top:44px; margin-bottom:14px; font-weight:600; }
.legal-doc h3{ font-size:17px; margin-top:26px; margin-bottom:10px; font-weight:600; }
.legal-doc p{ font-size:15px; line-height:1.8; color:var(--ink); margin:0 0 14px; }
.legal-doc ul, .legal-doc ol{ margin:0 0 16px; padding-left:22px; }
.legal-doc li{ font-size:15px; line-height:1.8; margin-bottom:8px; }
.legal-doc table{ width:100%; border-collapse:collapse; margin:20px 0; font-size:14px; }
.legal-doc td, .legal-doc th{ border:1px solid var(--line); padding:10px 14px; text-align:left; }
.legal-doc th{ background:rgba(43,33,21,.05); font-weight:600; }
.legal-doc strong{ font-weight:700; }
.legal-index{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:20px; }
.legal-index a{
  display:block; padding:18px 20px; border:1px solid var(--line); border-radius:14px; font-size:14.5px; font-weight:600;
  transition: all .3s var(--ease);
}
.legal-index a:hover{ background:var(--walnut); color:var(--paper); transform:translateY(-2px); }
@media (max-width:600px){ .legal-index{ grid-template-columns:1fr; } }
