/* =========================================================================
   LEND LUXE — Design System
   Black & gold luxe. Editorial serif + clean sans.
   Shared by the pitch site (index.html) and all prototype screens.
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

:root{
  /* Surfaces */
  --bg:        #0a0a0b;
  --bg-2:      #0f0f12;
  --panel:     #17171c;
  --panel-2:   #1e1e25;
  --panel-3:   #25252e;
  --line:      #2c2c35;
  --line-soft: #232329;

  /* Gold */
  --gold:      #c9a24a;
  --gold-2:    #e7c97a;
  --gold-3:    #9c7a2e;
  --gold-grad: linear-gradient(135deg, #f0d692 0%, #c9a24a 55%, #9c7a2e 100%);
  --gold-soft: rgba(201,162,74,.12);

  /* Ink */
  --ink:       #f5f2ea;
  --ink-2:     #d8d4ca;
  --muted:     #a2a2ad;
  --muted-2:   #74747f;

  /* Status */
  --green:     #5fb98c;
  --red:       #e06a6a;
  --blue:      #6aa6e0;
  --amber:     #e0b46a;

  /* Type */
  --serif: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  --radius:   14px;
  --radius-s: 10px;
  --radius-l: 22px;
  --shadow:   0 24px 60px -20px rgba(0,0,0,.7);
  --maxw:     1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:96px 0;position:relative}
.section--tight{padding:64px 0}
.center{text-align:center}
.grid{display:grid;gap:24px}
@media(max-width:860px){.section{padding:64px 0}}

/* ---- Eyebrow / labels ---- */
.eyebrow{
  font-size:12px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-2);font-weight:600;margin:0 0 18px;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}
.center .eyebrow::after{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}
.center .eyebrow{justify-content:center}

/* ---- Headings ---- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.05;margin:0 0 .4em;letter-spacing:.01em}
h1{font-size:clamp(40px,6.5vw,78px);font-weight:600}
h2{font-size:clamp(30px,4.4vw,52px)}
h3{font-size:clamp(22px,2.6vw,30px)}
.lede{font-size:clamp(17px,2vw,21px);color:var(--ink-2);max-width:62ch;font-weight:300;line-height:1.65}
.muted{color:var(--muted)}
.gold-text{
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
em.serif-em{font-style:italic;color:var(--gold-2)}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:none;
  padding:14px 26px;border-radius:999px;font-weight:600;font-size:14.5px;
  letter-spacing:.02em;transition:.25s ease;white-space:nowrap;
}
.btn--gold{background:var(--gold-grad);color:#1a1406;box-shadow:0 10px 30px -10px rgba(201,162,74,.6)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 16px 40px -12px rgba(201,162,74,.7)}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold-2)}
.btn--sm{padding:10px 18px;font-size:13px}
.btn--block{width:100%;justify-content:center}

/* ---- Pills / badges ---- */
.pill{
  display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:999px;
  font-size:12.5px;font-weight:500;border:1px solid var(--line);color:var(--ink-2);
  background:var(--panel);
}
.pill--gold{border-color:rgba(201,162,74,.4);color:var(--gold-2);background:var(--gold-soft)}
.pill--green{border-color:rgba(95,185,140,.35);color:var(--green);background:rgba(95,185,140,.08)}
.pill--red{border-color:rgba(224,106,106,.35);color:var(--red);background:rgba(224,106,106,.08)}
.dot{width:7px;height:7px;border-radius:50%;background:currentColor;display:inline-block}

/* ---- Cards ---- */
.card{
  background:linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:28px;transition:.3s ease;position:relative;overflow:hidden;
}
.card:hover{border-color:rgba(201,162,74,.35);transform:translateY(-4px)}
.card .ic{
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:var(--gold-soft);border:1px solid rgba(201,162,74,.25);margin-bottom:18px;color:var(--gold-2);
}
.card h3{font-size:22px;margin-bottom:.35em}
.card p{color:var(--muted);font-size:14.5px;margin:0;line-height:1.6}

/* ---- Hairline divider ---- */
.hr-gold{height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.5;border:0;margin:0}

/* ============================ NAV ============================ */
.nav{
  position:sticky;top:0;z-index:80;backdrop-filter:blur(14px);
  background:rgba(10,10,11,.72);border-bottom:1px solid var(--line-soft);
}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav__links{display:flex;gap:30px;align-items:center}
.nav__links a{font-size:13.5px;color:var(--muted);font-weight:500;transition:.2s;letter-spacing:.02em}
.nav__links a:hover{color:var(--gold-2)}
.nav__cta{display:flex;gap:12px;align-items:center}
.nav__burger{display:none;background:none;border:1px solid var(--line);border-radius:8px;padding:8px 10px;color:var(--ink);cursor:pointer}
@media(max-width:980px){
  .nav__links{display:none}
  .nav__burger{display:block}
  .nav__links.open{
    display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;
    background:var(--bg-2);padding:18px 24px;gap:18px;border-bottom:1px solid var(--line);
  }
}

/* ---- Logo ---- */
.logo{display:inline-flex;align-items:center;gap:12px}
.logo__mark{width:34px;height:34px;flex:0 0 auto}
.logo__txt{font-family:var(--serif);font-weight:600;font-size:23px;letter-spacing:.06em;color:var(--ink)}
.logo__txt b{color:var(--gold-2);font-weight:600}

/* ============================ HERO ============================ */
.hero{position:relative;overflow:hidden;padding:90px 0 110px}
.hero__glow{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(60% 50% at 78% 18%, rgba(201,162,74,.16), transparent 60%),
    radial-gradient(50% 40% at 12% 88%, rgba(201,162,74,.08), transparent 60%);
}
.hero__grid{position:absolute;inset:0;z-index:0;opacity:.35;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(70% 60% at 50% 30%,#000,transparent 75%)}
.hero__in{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{margin-bottom:.25em}
.hero .lede{margin:0 0 32px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero__meta{display:flex;gap:26px;flex-wrap:wrap;color:var(--muted);font-size:13.5px}
.hero__meta b{color:var(--ink);font-family:var(--serif);font-size:26px;display:block;font-weight:600}
@media(max-width:920px){.hero__in{grid-template-columns:1fr;gap:36px}.hero__art{order:-1}}

/* Hero art — stacked bag cards */
.hero__art{position:relative;height:440px}
.bagcard{
  position:absolute;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);background:var(--panel);
}
.bagcard--a{width:240px;height:300px;left:8%;top:60px;transform:rotate(-6deg);z-index:2}
.bagcard--b{width:230px;height:288px;right:6%;top:0;transform:rotate(5deg);z-index:3}
.bagcard--c{width:210px;height:250px;left:38%;bottom:0;transform:rotate(-2deg);z-index:4}
@media(max-width:920px){.hero__art{height:340px}.bagcard--a{left:2%}.bagcard--b{right:2%}}

/* Stylized "bag" tile (used everywhere as product placeholder) */
.bagtile{position:relative;width:100%;height:100%;display:grid;place-items:center;overflow:hidden}
.bagtile__brand{position:absolute;bottom:12px;left:14px;font-family:var(--serif);font-size:15px;letter-spacing:.18em;color:var(--ink);z-index:2;text-transform:uppercase}
.bagtile__tag{position:absolute;top:12px;right:12px;z-index:2}
.bagtile svg{width:62%;height:62%;opacity:.9;filter:drop-shadow(0 8px 20px rgba(0,0,0,.5))}

/* ============================ STATS STRIP ============================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden}
.stats>div{padding:30px 26px;border-right:1px solid var(--line-soft)}
.stats>div:last-child{border-right:0}
.stats b{font-family:var(--serif);font-size:40px;font-weight:600;display:block;line-height:1}
.stats span{font-size:13px;color:var(--muted);margin-top:6px;display:block}
@media(max-width:780px){.stats{grid-template-columns:1fr 1fr}.stats>div:nth-child(2){border-right:0}}

/* ============================ STEP / HOW ============================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:step}
.step{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);padding:26px;position:relative}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--serif);font-size:34px;color:var(--gold-2);opacity:.7;display:block;margin-bottom:12px}
.step h4{font-size:19px;margin-bottom:.3em}
.step p{color:var(--muted);font-size:13.5px;margin:0}
@media(max-width:860px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}

/* Two-column split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:30px}}

/* Pricing calc box */
.calc{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:8px}
.calc__row{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line-soft)}
.calc__row:last-child{border-bottom:0}
.calc__row span{color:var(--muted);font-size:14px}
.calc__row b{font-family:var(--serif);font-size:22px}
.calc__row--total{background:var(--gold-soft);border-radius:10px}
.calc__row--total b{color:var(--gold-2);font-size:28px}

/* ============================ FEATURE GRID ============================ */
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.fgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.fgrid{grid-template-columns:1fr}}

/* ============================ RISK SECTION ============================ */
.risk{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:780px){.risk{grid-template-columns:1fr}}
.riskcard{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);padding:26px;border-left:3px solid var(--red)}
.riskcard h4{display:flex;align-items:center;gap:10px;font-size:20px;color:var(--ink);margin-bottom:14px}
.riskcard .threat{color:var(--muted);font-size:14px;margin:0 0 16px;padding-bottom:16px;border-bottom:1px dashed var(--line)}
.riskcard ul{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.riskcard li{display:flex;gap:10px;font-size:13.7px;color:var(--ink-2);line-height:1.5}
.riskcard li::before{content:"✓";color:var(--green);font-weight:700;flex:0 0 auto}

/* Defense-in-depth layers */
.layers{display:grid;gap:12px}
.layer{display:flex;align-items:center;gap:16px;background:var(--panel);border:1px solid var(--line-soft);border-radius:12px;padding:16px 20px}
.layer__n{font-family:var(--serif);font-size:24px;color:var(--gold-2);width:40px;flex:0 0 auto}
.layer h4{margin:0 0 2px;font-size:17px}
.layer p{margin:0;color:var(--muted);font-size:13.3px}

/* ============================ TECH / ARCH ============================ */
.arch{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-l);padding:30px;overflow:hidden}
.arch__row{display:grid;gap:14px;margin-bottom:14px}
.arch__row:last-child{margin-bottom:0}
.tier{display:grid;grid-template-columns:140px 1fr;gap:18px;align-items:center}
.tier__label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);font-weight:600;text-align:right}
.tier__nodes{display:flex;gap:10px;flex-wrap:wrap}
.node{
  background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:11px 15px;
  font-size:13px;color:var(--ink-2);display:inline-flex;align-items:center;gap:8px;font-weight:500;
}
.node b{color:var(--ink);font-weight:600}
.node--gold{border-color:rgba(201,162,74,.4);background:var(--gold-soft);color:var(--gold-2)}
@media(max-width:680px){.tier{grid-template-columns:1fr}.tier__label{text-align:left}}

.techlist{columns:2;column-gap:40px}
.techlist li{break-inside:avoid;margin-bottom:14px;list-style:none;padding-left:22px;position:relative;font-size:14px;color:var(--ink-2)}
.techlist li::before{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;background:var(--gold-grad);border-radius:2px;transform:rotate(45deg)}
.techlist li b{color:var(--ink)}
@media(max-width:680px){.techlist{columns:1}}

/* ============================ SHOWCASE (device frames) ============================ */
.showcase{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center}
@media(max-width:860px){.showcase{grid-template-columns:1fr}}
.browserframe{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--bg-2);box-shadow:var(--shadow)}
.browserframe__bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:var(--panel);border-bottom:1px solid var(--line)}
.browserframe__bar i{width:11px;height:11px;border-radius:50%;background:var(--line);display:block}
.browserframe__url{margin-left:12px;font-size:12px;color:var(--muted);background:var(--bg);border-radius:6px;padding:5px 12px;flex:1}
.phoneframe{width:230px;border:8px solid #1a1a20;border-radius:34px;overflow:hidden;background:#000;box-shadow:var(--shadow);margin:0 auto}
.phoneframe__notch{height:22px;background:#1a1a20;border-radius:0 0 14px 14px;width:120px;margin:0 auto}

/* ============================ MARKETING ============================ */
.chan{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:780px){.chan{grid-template-columns:1fr}}
.chan__card{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);padding:24px}
.chan__card h4{font-size:18px;display:flex;align-items:center;gap:10px;margin-bottom:10px}
.chan__card p{color:var(--muted);font-size:13.5px;margin:0 0 12px}
.chan__card .kpi{font-size:12px;color:var(--gold-2);font-weight:600;letter-spacing:.04em}

.funnel{display:grid;gap:10px}
.funnel__step{display:flex;justify-content:space-between;align-items:center;padding:15px 22px;border-radius:10px;background:var(--panel);border:1px solid var(--line-soft)}
.funnel__step span{color:var(--muted);font-size:13px}
.funnel__step b{font-family:var(--serif);font-size:20px}

/* ============================ ROADMAP ============================ */
.timeline{position:relative;padding-left:0}
.phase{display:grid;grid-template-columns:160px 1fr;gap:26px;padding:24px 0;border-top:1px solid var(--line-soft)}
.phase:first-child{border-top:0}
.phase__when{font-family:var(--serif);font-size:22px;color:var(--gold-2)}
.phase__when small{display:block;font-family:var(--sans);font-size:12px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:4px}
.phase__body h4{font-size:20px;margin-bottom:8px}
.phase__body p{color:var(--muted);font-size:14px;margin:0 0 12px}
.tags{display:flex;gap:8px;flex-wrap:wrap}
.tags .pill{font-size:11.5px;padding:4px 11px}
@media(max-width:680px){.phase{grid-template-columns:1fr;gap:8px}}

/* ============================ OPINION / CALLOUT ============================ */
.callout{
  background:linear-gradient(180deg,var(--gold-soft),transparent);
  border:1px solid rgba(201,162,74,.3);border-radius:var(--radius-l);padding:36px;
}
.callout--warn{background:linear-gradient(180deg,rgba(224,106,106,.08),transparent);border-color:rgba(224,106,106,.3)}
.callout h3{color:var(--gold-2)}
.callout--warn h3{color:#f0a0a0}

.compare{width:100%;border-collapse:collapse;font-size:13.7px}
.compare th,.compare td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line-soft)}
.compare th{color:var(--gold-2);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.compare td:first-child{color:var(--ink);font-weight:600}
.compare .y{color:var(--green)}
.compare .n{color:var(--red)}
.compare tr:hover td{background:var(--panel)}

/* ============================ FOOTER ============================ */
.footer{border-top:1px solid var(--line-soft);padding:54px 0 36px;margin-top:30px}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px;margin-bottom:40px}
@media(max-width:780px){.footer__grid{grid-template-columns:1fr 1fr}}
.footer h5{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);margin:0 0 16px}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.footer a{color:var(--muted);font-size:13.5px}
.footer a:hover{color:var(--gold-2)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding-top:24px;border-top:1px solid var(--line-soft);color:var(--muted-2);font-size:12.5px}

/* ---- Scroll reveal ---- */
.reveal{opacity:0;transform:translateY(22px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---- Section heading block ---- */
.shead{max-width:680px;margin:0 0 48px}
.center.shead{margin-left:auto;margin-right:auto}

/* ---- Demo banner ---- */
.demobar{background:var(--gold-grad);color:#1a1406;text-align:center;font-size:12.5px;font-weight:600;padding:8px 16px;letter-spacing:.02em}
.demobar a{text-decoration:underline}

/* ---- Utility ---- */
.mt-s{margin-top:14px}.mt-m{margin-top:26px}.mt-l{margin-top:44px}
.flex{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.note{font-size:12px;color:var(--muted-2);font-style:italic}

/* =========================================================================
   PROTOTYPE APP SHELL  (search / product / owner / admin)
   ========================================================================= */
.appbar{position:sticky;top:0;z-index:90;background:rgba(10,10,11,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft)}
.appbar__in{display:flex;align-items:center;gap:18px;height:64px;max-width:1320px;margin:0 auto;padding:0 22px}
.appbar__search{flex:1;max-width:520px;display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:9px 16px}
.appbar__search input{flex:1;background:none;border:0;color:var(--ink);font-size:14px;outline:none}
.appbar__search input::placeholder{color:var(--muted-2)}
.segnav{display:flex;gap:4px;background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:4px}
.segnav a{font-size:12.5px;padding:7px 14px;border-radius:999px;color:var(--muted);font-weight:500}
.segnav a.active{background:var(--gold-grad);color:#1a1406}
.appbar__profile{width:36px;height:36px;border-radius:50%;background:var(--gold-grad);display:grid;place-items:center;color:#1a1406;font-weight:700;font-size:14px;flex:0 0 auto}
@media(max-width:820px){.appbar__search{display:none}.segnav a{padding:7px 10px}}

.applayout{max-width:1320px;margin:0 auto;padding:26px 22px;display:grid;grid-template-columns:280px 1fr;gap:26px;align-items:start}
@media(max-width:920px){.applayout{grid-template-columns:1fr}}

/* ---- Filter sidebar ---- */
.filters{position:sticky;top:88px;background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);padding:22px}
.filters h4{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin:22px 0 12px}
.filters h4:first-child{margin-top:0}
.fopt{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:14px;color:var(--ink-2);cursor:pointer}
.fopt input{accent-color:var(--gold)}
.range{display:flex;align-items:center;gap:10px;margin-top:8px}
.range input[type=range]{width:100%;accent-color:var(--gold)}
.range .val{font-family:var(--serif);font-size:18px;color:var(--gold-2);min-width:54px}
.chiprow{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-size:12.5px;padding:6px 12px;border-radius:999px;border:1px solid var(--line);color:var(--ink-2);cursor:pointer;user-select:none;transition:.15s}
.chip.on{background:var(--gold-soft);border-color:rgba(201,162,74,.5);color:var(--gold-2)}
.fld{width:100%;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;color:var(--ink);padding:11px 13px;font-size:14px;font-family:inherit}
.fld:focus{outline:none;border-color:var(--gold)}

/* ---- Results ---- */
.resbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;flex-wrap:wrap;gap:12px}
.resbar h2{margin:0;font-size:26px}
.lgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:1180px){.lgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.lgrid{grid-template-columns:1fr}}

.listing{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden;transition:.25s;cursor:pointer;display:block}
.listing:hover{border-color:rgba(201,162,74,.4);transform:translateY(-4px)}
.listing__media{aspect-ratio:4/5;position:relative;border-bottom:1px solid var(--line-soft)}
.listing__fav{position:absolute;top:10px;right:10px;z-index:3;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.45);border:1px solid var(--line);display:grid;place-items:center;color:#fff;backdrop-filter:blur(4px)}
.listing__body{padding:15px 16px}
.listing__top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.listing__brand{font-family:var(--serif);font-size:19px;font-weight:600}
.listing__model{color:var(--muted);font-size:13px;margin:2px 0 10px}
.listing__meta{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:var(--muted);border-top:1px solid var(--line-soft);padding-top:11px;margin-top:4px}
.price{font-family:var(--serif);font-size:22px;color:var(--gold-2);font-weight:600}
.price small{font-size:12px;color:var(--muted);font-family:var(--sans)}
.stars{color:var(--gold-2);font-size:13px}

.empty{text-align:center;padding:60px 20px;color:var(--muted)}

/* =========================================================================
   PRODUCT PAGE
   ========================================================================= */
.pdp{max-width:1180px;margin:0 auto;padding:26px 22px}
.pdp__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:34px;align-items:start}
@media(max-width:920px){.pdp__grid{grid-template-columns:1fr}}
.gallery__main{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);position:relative}
.gallery__thumbs{display:flex;gap:10px;margin-top:12px}
.gallery__thumbs .t{width:78px;height:78px;border-radius:10px;overflow:hidden;border:1px solid var(--line);cursor:pointer;opacity:.6;transition:.2s}
.gallery__thumbs .t.on,.gallery__thumbs .t:hover{opacity:1;border-color:var(--gold)}
.playbadge{position:absolute;inset:0;display:grid;place-items:center;z-index:3;pointer-events:none}
.playbadge span{width:54px;height:54px;border-radius:50%;background:rgba(0,0,0,.5);border:1px solid var(--gold);display:grid;place-items:center;color:var(--gold-2);font-size:20px}

.book{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;position:sticky;top:88px}
.book__price{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}
.book__price b{font-family:var(--serif);font-size:34px;color:var(--gold-2)}
.daterow{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:16px 0}
.daterow label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);display:block;margin-bottom:6px}
.summary{border-top:1px solid var(--line-soft);margin-top:16px;padding-top:14px;display:grid;gap:9px}
.summary .r{display:flex;justify-content:space-between;font-size:13.5px;color:var(--muted)}
.summary .r b{color:var(--ink);font-weight:500}
.summary .r--total{border-top:1px solid var(--line-soft);padding-top:12px;margin-top:4px;font-size:16px;color:var(--ink)}
.summary .r--total b{font-family:var(--serif);font-size:24px;color:var(--gold-2)}
.summary .r--deposit b{color:var(--ink-2)}

/* mini calendar */
.cal{background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:14px;margin-top:6px}
.cal__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.cal__head b{font-family:var(--serif);font-size:18px}
.cal__nav{background:var(--panel);border:1px solid var(--line);border-radius:8px;color:var(--ink);width:30px;height:30px;cursor:pointer}
.cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal__dow{font-size:10px;color:var(--muted-2);text-align:center;padding:4px 0;letter-spacing:.05em}
.cal__day{aspect-ratio:1;display:grid;place-items:center;font-size:12.5px;border-radius:8px;cursor:pointer;color:var(--ink-2);border:1px solid transparent;position:relative}
.cal__day:hover:not(.off){border-color:var(--gold)}
.cal__day.off{color:var(--muted-2);opacity:.35;cursor:not-allowed;text-decoration:line-through}
.cal__day.booked{background:rgba(224,106,106,.14);color:var(--red);cursor:not-allowed}
.cal__day.sel{background:var(--gold-grad);color:#1a1406;font-weight:700}
.cal__day.inrange{background:var(--gold-soft);color:var(--gold-2);border-radius:0}
.cal__day.muted-day{visibility:hidden}
.callegend{display:flex;gap:16px;margin-top:10px;font-size:11px;color:var(--muted)}
.callegend i{width:10px;height:10px;border-radius:3px;display:inline-block;margin-right:5px;vertical-align:middle}

#map{height:280px;border-radius:var(--radius);border:1px solid var(--line);z-index:0}
.leaflet-container{background:var(--bg-2)!important}

.specrow{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden;margin-top:14px}
.specrow div{padding:14px 18px;border-bottom:1px solid var(--line-soft);border-right:1px solid var(--line-soft);font-size:13.5px}
.specrow span{color:var(--muted-2);display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px}
.ownerbox{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);padding:16px 18px;margin-top:14px}
.ownerbox .av{width:48px;height:48px;border-radius:50%;background:var(--gold-grad);display:grid;place-items:center;color:#1a1406;font-weight:700}

/* =========================================================================
   OWNER + ADMIN DASHBOARDS
   ========================================================================= */
.dash{max-width:1320px;margin:0 auto;padding:26px 22px}
.dhead{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:14px;margin-bottom:24px}
.dhead h1{font-size:38px;margin:0}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
@media(max-width:920px){.kpis{grid-template-columns:1fr 1fr}}
.kpi{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);padding:20px 22px}
.kpi span{font-size:12px;color:var(--muted);letter-spacing:.04em}
.kpi b{font-family:var(--serif);font-size:34px;font-weight:600;display:block;margin-top:6px;line-height:1}
.kpi .delta{font-size:12px;margin-top:8px;display:inline-flex;gap:5px;align-items:center}
.kpi .up{color:var(--green)}.kpi .down{color:var(--red)}

.panel{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--radius);padding:22px}
.panel h3{font-size:22px;margin:0 0 4px}
.panel .sub{color:var(--muted);font-size:13px;margin:0 0 18px}
.dgrid{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;margin-bottom:20px}
@media(max-width:920px){.dgrid{grid-template-columns:1fr}}

.dtable{width:100%;border-collapse:collapse;font-size:13.5px}
.dtable th{text-align:left;color:var(--muted-2);font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:0 14px 12px;border-bottom:1px solid var(--line)}
.dtable td{padding:14px;border-bottom:1px solid var(--line-soft);color:var(--ink-2)}
.dtable tr:hover td{background:var(--bg-2)}
.dtable .b{color:var(--ink);font-weight:600}
.avatar-s{width:30px;height:30px;border-radius:50%;background:var(--panel-3);display:inline-grid;place-items:center;font-size:12px;color:var(--gold-2);border:1px solid var(--line);margin-right:8px;vertical-align:middle}

/* owner availability calendar (big) */
.bigcal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.bigcal .dow{font-size:11px;color:var(--muted-2);text-align:center;padding:6px 0;letter-spacing:.08em;text-transform:uppercase}
.bigcal .d{aspect-ratio:1.1;border:1px solid var(--line-soft);border-radius:9px;padding:7px 9px;font-size:12px;cursor:pointer;position:relative;transition:.12s;background:var(--bg-2)}
.bigcal .d:hover{border-color:var(--gold)}
.bigcal .d.blocked{background:rgba(116,116,127,.12);color:var(--muted-2)}
.bigcal .d.booked{background:rgba(201,162,74,.14);border-color:rgba(201,162,74,.4)}
.bigcal .d.booked::after{content:"Booked";position:absolute;bottom:6px;left:8px;font-size:9px;color:var(--gold-2);letter-spacing:.04em}
.bigcal .d.blocked::after{content:"Blocked";position:absolute;bottom:6px;left:8px;font-size:9px;color:var(--muted-2)}
.bigcal .d.empty{visibility:hidden}

.tabbar{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:22px;flex-wrap:wrap}
.tabbar button{background:none;border:0;color:var(--muted);font-size:14px;font-weight:500;padding:11px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.tabbar button.active{color:var(--gold-2);border-bottom-color:var(--gold)}

.bars{display:grid;gap:12px;margin-top:6px}
.bar{display:grid;grid-template-columns:90px 1fr 50px;gap:12px;align-items:center;font-size:12.5px;color:var(--muted)}
.bar .track{height:9px;background:var(--bg-2);border-radius:6px;overflow:hidden;border:1px solid var(--line-soft)}
.bar .fill{height:100%;background:var(--gold-grad);border-radius:6px}
.bar b{color:var(--ink);text-align:right;font-family:var(--serif);font-size:15px}

.statuschip{font-size:11.5px;padding:4px 10px;border-radius:999px;font-weight:600}
.s-active{background:rgba(95,185,140,.14);color:var(--green)}
.s-pending{background:rgba(224,180,106,.14);color:var(--amber)}
.s-dispute{background:rgba(224,106,106,.14);color:var(--red)}
.s-returned{background:rgba(116,116,127,.16);color:var(--muted)}

.backlink{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;margin-bottom:18px}
.backlink:hover{color:var(--gold-2)}

/* ---- Competitor table links + highlighted row ---- */
.compare a{color:var(--ink);border-bottom:1px solid rgba(201,162,74,.35)}
.compare a:hover{color:var(--gold-2)}
.compare tr.you-row td{background:var(--gold-soft)}
.compare tr.you-row td:first-child{color:var(--gold-2)}
.compare .mid{color:var(--amber)}

/* ---- Competitive positioning 2×2 map ---- */
.posmap{position:relative;aspect-ratio:16/10;min-height:380px;background:radial-gradient(120% 90% at 78% 22%,var(--gold-soft),transparent 55%),var(--panel);border:1px solid var(--line);border-radius:var(--radius-l);margin-top:18px;overflow:hidden}
.posmap__cross::before,.posmap__cross::after{content:"";position:absolute;background:var(--line)}
.posmap__cross::before{left:50%;top:7%;bottom:7%;width:1px;transform:translateX(-.5px)}
.posmap__cross::after{top:50%;left:7%;right:7%;height:1px;transform:translateY(-.5px)}
.posmap__white{position:absolute;top:9%;right:5%;width:40%;height:39%;border:1.5px dashed rgba(201,162,74,.55);border-radius:14px}
.posmap__white em{position:absolute;bottom:7px;right:10px;font-size:9.5px;color:var(--gold-2);font-style:normal;letter-spacing:.14em;text-transform:uppercase}
.posmap__axis{position:absolute;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);font-weight:700}
.posmap__axis.t{top:12px;left:50%;transform:translateX(-50%)}
.posmap__axis.b{bottom:12px;left:50%;transform:translateX(-50%)}
.posmap__axis.l{left:16px;top:50%;transform:translateY(-50%);writing-mode:vertical-rl;rotate:180deg}
.posmap__axis.r{right:16px;top:50%;transform:translateY(-50%);writing-mode:vertical-rl}
.dotc{position:absolute;transform:translate(-50%,-50%);text-align:center;width:max-content;max-width:110px;z-index:2}
.dotc i{display:block;width:10px;height:10px;border-radius:50%;background:var(--muted);margin:0 auto 5px;border:2px solid var(--bg)}
.dotc span{font-size:10.5px;color:var(--ink-2);line-height:1.15;display:block}
.dotc.ie i{background:var(--blue)}
.dotc.uk i{background:var(--muted-2)}
.dotc.you i{width:20px;height:20px;background:var(--gold-grad);box-shadow:0 0 0 5px var(--gold-soft),0 0 26px rgba(201,162,74,.7)}
.dotc.you span{color:var(--gold-2);font-family:var(--serif);font-size:17px;font-weight:600;margin-top:2px}
@media(max-width:680px){.posmap{aspect-ratio:auto;height:460px}.dotc span{font-size:9.5px}}
