/* ====================================================================
   Maskan — app.css
   Design tokens + components lifted verbatim from the approved concept
   (maskan-concept.html, the design source of truth). Catalog / detail /
   placeholder styles are appended at the end under 'STAGE-1 ADDITIONS'.
   ==================================================================== */

  :root{
    --ivory:#f7f3ea; --paper:#fffdf8; --stone:#efe8d8;
    --emerald-900:#0a2419; --emerald-800:#0c3122; --emerald:#0c4d35; --emerald-700:#0a3f2b; --emerald-300:#5fa583;
    --gold:#b58a2c; --gold-2:#d6b260; --gold-soft:#e9d5a3;
    --ink:#1a231e; --muted:#5d6760;
    --line:#e6dfce; --line-2:#ddd3bd;
    --clay:#a33b2e;
    --r:14px; --r-sm:10px; --r-lg:22px;
    --shadow:0 1px 0 rgba(26,35,30,.04), 0 22px 48px -34px rgba(12,77,53,.4);
    --shadow-lg:0 34px 70px -38px rgba(10,36,25,.55);
    --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
    --ar:"Tajawal",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,"Noto Sans Arabic",Arial,sans-serif;
    --maxw:1200px; --dur:6500ms;
    --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%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");
  }
  *{box-sizing:border-box}
  html,body{margin:0}
  body{font-family:var(--ar); color:var(--ink); background:var(--ivory); line-height:1.7; -webkit-font-smoothing:antialiased; overflow-x:hidden}
  .grain{position:fixed; inset:0; background-image:var(--grain); background-size:140px; opacity:.05; pointer-events:none; z-index:60; mix-blend-mode:multiply}
  .wrap{max-width:var(--maxw); margin-inline:auto; padding-inline:24px}
  a{color:inherit; text-decoration:none}
  button{font-family:inherit}
  ::selection{background:var(--gold-soft)}
  :focus-visible{outline:2.5px solid var(--gold); outline-offset:3px; border-radius:5px}
  .figure{font-family:var(--serif); font-variant-numeric:tabular-nums lining-nums; font-weight:600; letter-spacing:0}
  .eyebrow{font-family:var(--serif); font-style:italic; font-size:15px; letter-spacing:.04em; color:var(--gold); display:inline-flex; align-items:center; gap:10px}
  .eyebrow::before{content:""; width:26px; height:1px; background:var(--gold); opacity:.7}
  html[lang=ar] .eyebrow{font-family:var(--ar); font-style:normal; font-weight:700; font-size:13.5px}
  .skip{position:absolute; inset-inline-start:-9999px; top:0; background:var(--emerald); color:#fff; padding:10px 16px; z-index:200}
  .skip:focus{inset-inline-start:0}

  /* ---------- buttons ---------- */
  .btn{display:inline-flex; align-items:center; justify-content:center; gap:9px; border:0; cursor:pointer; font-weight:700; font-size:15px; padding:13px 24px; border-radius:999px; transition:transform .2s, box-shadow .2s, background .2s, color .2s; letter-spacing:.01em}
  .btn:active{transform:translateY(1px)}
  .btn-gold{background:var(--gold); color:#241a05; box-shadow:0 12px 26px -14px rgba(181,138,44,.9)} .btn-gold:hover{background:var(--gold-2)}
  .btn-emerald{background:var(--emerald); color:#fff} .btn-emerald:hover{background:var(--emerald-700)}
  .btn-wa{background:#1fab54; color:#fff} .btn-wa:hover{background:#178f45}
  .btn-line{background:transparent; border:1.5px solid var(--line-2); color:var(--ink)} .btn-line:hover{border-color:var(--gold); color:var(--emerald)}
  .btn-line-light{background:transparent; border:1.5px solid rgba(255,255,255,.35); color:#fff} .btn-line-light:hover{border-color:var(--gold-2); background:rgba(255,255,255,.06)}
  .btn-sm{padding:10px 16px; font-size:13.5px}
  .icon{width:17px; height:17px; flex:0 0 auto}

  /* ---------- header ---------- */
  header.nav{position:fixed; inset-inline:0; top:0; z-index:100; transition:background .35s, box-shadow .35s, border-color .35s}
  .nav-inner{display:flex; align-items:center; gap:18px; height:76px}
  .brand{display:flex; align-items:center; gap:11px; font-weight:800; font-size:22px; color:#fff; transition:color .35s}
  .brand .latin{font-family:var(--serif); font-weight:600; font-style:italic; opacity:.92; font-size:18px; margin-inline-start:2px}
  .brand .mark{width:38px; height:38px; flex:0 0 auto}
  .nav-links{display:flex; gap:4px; margin-inline-start:18px}
  .nav-links a{padding:9px 13px; border-radius:8px; color:rgba(255,255,255,.82); font-weight:600; font-size:14.5px; transition:color .25s, background .25s}
  .nav-links a:hover{color:#fff; background:rgba(255,255,255,.1)}
  .nav-right{margin-inline-start:auto; display:flex; align-items:center; gap:11px}
  .lang{border:1.5px solid rgba(255,255,255,.35); background:transparent; color:#fff; border-radius:999px; padding:8px 14px; font-weight:700; font-size:13px; cursor:pointer; display:inline-flex; gap:7px; align-items:center; transition:border-color .25s, color .35s, background .25s}
  .lang:hover{border-color:var(--gold-2)}
  /* scrolled state */
  header.nav.scrolled{background:rgba(247,243,234,.9); backdrop-filter:saturate(150%) blur(12px); box-shadow:0 1px 0 var(--line); border-bottom:1px solid var(--line)}
  header.nav.scrolled .brand{color:var(--ink)}
  header.nav.scrolled .nav-links a{color:var(--muted)} header.nav.scrolled .nav-links a:hover{color:var(--ink); background:#ece4d4}
  header.nav.scrolled .lang{border-color:var(--line-2); color:var(--ink)}

  /* ---------- HERO SLIDER ---------- */
  .hero{position:relative; min-height:92vh; display:flex; align-items:center; overflow:hidden; background:var(--emerald-900)}
  .slides{position:absolute; inset:0}
  .slide{position:absolute; inset:0; opacity:0; visibility:hidden; transition:opacity 1.1s ease, visibility 1.1s}
  .slide.active{opacity:1; visibility:visible}
  .slide-bg{position:absolute; inset:0; transform:scale(1.02)}
  .slide.active .slide-bg{animation:kenburns 9s ease-out forwards}
  @keyframes kenburns{from{transform:scale(1.02)} to{transform:scale(1.14)}}
  .slide-bg svg{width:100%; height:100%}
  .slide-overlay{position:absolute; inset:0; background:
     linear-gradient(105deg, rgba(8,28,19,.92) 0%, rgba(8,28,19,.6) 42%, rgba(8,28,19,.18) 75%),
     linear-gradient(to top, rgba(8,28,19,.6), transparent 38%)}
  html[dir=ltr] .slide-overlay{background:linear-gradient(255deg, rgba(8,28,19,.92) 0%, rgba(8,28,19,.6) 42%, rgba(8,28,19,.18) 75%), linear-gradient(to top, rgba(8,28,19,.6), transparent 38%)}
  .hero-slider{position:relative; z-index:2; width:100%; touch-action:pan-y}
  .slide-content{display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; padding-block:120px 90px}
  .slide-copy{color:#fff; opacity:0}
  .slide.active .slide-copy{animation:rise .9s .25s ease both}
  @keyframes rise{from{opacity:0; transform:translateY(26px)} to{opacity:1; transform:none}}
  .slide-copy h2{font-family:var(--ar); font-weight:900; font-size:clamp(34px,5vw,60px); line-height:1.1; letter-spacing:-.01em; margin:16px 0 16px}
  html[lang=en] .slide-copy h2{font-family:var(--serif); font-weight:600; letter-spacing:.005em}
  .slide-copy h2 .hl{color:var(--gold-2)}
  .slide-copy p{font-size:clamp(16px,1.6vw,19px); color:rgba(255,255,255,.82); max-width:44ch; margin:0 0 26px}
  .slide-meta{display:flex; gap:9px; flex-wrap:wrap; margin-bottom:6px}
  .slide-meta .m{font-size:12.5px; font-weight:700; color:#fff; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18); padding:6px 12px; border-radius:999px; backdrop-filter:blur(3px)}

  /* clarity ledger card (signature, refined) */
  .ucard{background:rgba(255,253,248,.96); border:1px solid rgba(255,255,255,.6); border-radius:var(--r-lg); padding:24px; box-shadow:var(--shadow-lg); opacity:0}
  .slide.active .ucard{animation:rise .9s .42s ease both}
  .ucard .u-top{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:4px}
  .u-badge{font-size:12px; font-weight:800; color:#241a05; background:var(--gold); padding:5px 11px; border-radius:999px}
  .u-status{font-size:12px; font-weight:800; color:#fff; padding:5px 11px; border-radius:999px; display:inline-flex; align-items:center; gap:6px}
  .u-status .dot{width:7px; height:7px; border-radius:50%; background:#fff}
  .st-avail{background:var(--emerald)} .st-hold{background:var(--gold)} .st-sold{background:var(--clay)}
  .u-title{font-size:21px; font-weight:800; letter-spacing:-.01em; margin:8px 0 2px}
  .u-sub{font-size:13.5px; color:var(--muted); font-weight:600}
  .ledger{margin-top:16px; border-top:1px solid var(--line); padding-top:14px; display:grid; gap:11px}
  .lrow{display:flex; align-items:baseline; justify-content:space-between; gap:14px}
  .lrow .k{font-size:13px; font-weight:700; color:var(--muted)}
  .lrow .v{font-size:15px; font-weight:800; text-align:end}
  .lrow .v .figure{font-size:16px}
  .lrow.price .v{font-size:18px}
  .lrow.price .v .figure{font-size:25px; color:var(--emerald)}
  .lrow.price .was{font-size:13px; color:var(--clay); text-decoration:line-through; margin-inline-end:8px; font-weight:600}
  .lrow .unit{font-size:12px; color:var(--muted); font-weight:700}
  .lrow.deliver .v{color:var(--emerald-700)}
  .u-cta{display:flex; gap:9px; margin-top:18px; flex-wrap:wrap}
  .u-cta .btn{flex:1 1 auto}

  /* slider controls */
  .s-arrow{position:absolute; top:50%; transform:translateY(-50%); z-index:4; width:50px; height:50px; border-radius:50%; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.28); color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; backdrop-filter:blur(4px); transition:background .2s, border-color .2s}
  .s-arrow:hover{background:rgba(255,255,255,.2); border-color:var(--gold-2)}
  .s-prev{inset-inline-start:18px} .s-next{inset-inline-end:18px}
  .s-arrow svg{width:20px; height:20px}
  html[dir=rtl] .s-arrow svg{transform:scaleX(-1)}
  .s-dots{position:absolute; inset-inline:0; bottom:118px; z-index:4; display:flex; gap:10px; justify-content:center}
  .s-dots button{width:9px; height:9px; border-radius:50%; border:0; background:rgba(255,255,255,.4); cursor:pointer; padding:0; transition:width .3s, background .3s}
  .s-dots button.on{width:30px; border-radius:5px; background:var(--gold-2)}
  .s-progress{position:absolute; inset-inline:0; bottom:0; height:3px; background:rgba(255,255,255,.12); z-index:4}
  .s-progress span{display:block; height:100%; width:0; background:linear-gradient(90deg,var(--gold),var(--gold-2))}
  .s-progress span.run{animation:prog var(--dur) linear forwards}
  @keyframes prog{from{width:0} to{width:100%}}
  .hero.paused .s-progress span.run{animation-play-state:paused}

  /* ---------- search bar (overlap) ---------- */
  .searchwrap{position:relative; z-index:20; margin-top:-44px; margin-bottom:10px}
  .search{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:16px; box-shadow:var(--shadow-lg); display:grid; grid-template-columns:1fr 1fr 1fr auto; gap:12px; align-items:end}
  .field{display:flex; flex-direction:column; gap:6px}
  .field label{font-size:12px; font-weight:700; color:var(--muted)}
  .field select{appearance:none; -webkit-appearance:none; border:1.5px solid var(--line); border-radius:12px; padding:13px 15px; font-size:14.5px; background:var(--ivory); color:var(--ink); font-family:inherit; font-weight:600; cursor:pointer;
     background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%); background-position:16px 22px,21px 22px; background-size:5px 5px; background-repeat:no-repeat}
  html[dir=ltr] .field select{background-position:calc(100% - 21px) 22px,calc(100% - 16px) 22px}
  .field select:focus-visible{border-color:var(--gold)}
  .search .btn{height:49px; padding-inline:26px}
  .microtrust{display:flex; align-items:center; gap:9px; margin:14px 4px 0; font-size:13.5px; color:var(--muted); font-weight:600}
  .pulse{width:9px; height:9px; border-radius:50%; background:var(--emerald-300); animation:pulse 2.2s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(95,165,131,.55)}70%{box-shadow:0 0 0 9px rgba(95,165,131,0)}100%{box-shadow:0 0 0 0 rgba(95,165,131,0)}}

  /* ---------- trust + marquee ---------- */
  .trust{background:var(--emerald-900); color:#fff; padding-top:40px}
  .trust-inner{display:grid; grid-template-columns:repeat(4,1fr); gap:20px; padding-bottom:34px}
  .ti{display:flex; align-items:center; gap:14px}
  .ti .ic{width:38px; height:38px; color:var(--gold-2); flex:0 0 auto}
  .ti .big{font-family:var(--serif); font-weight:600; font-size:33px; line-height:1; color:#fff}
  .ti .big.txt{font-family:var(--ar); font-weight:800; font-size:19px}
  .ti .lab{font-size:13px; color:rgba(255,255,255,.7); font-weight:600; margin-top:3px}
  .ti + .ti{border-inline-start:1px solid rgba(255,255,255,.13); padding-inline-start:20px}
  .marquee{border-top:1px solid rgba(255,255,255,.12); overflow:hidden; padding:18px 0}
  .marquee-label{font-family:var(--serif); font-style:italic; font-size:14px; color:var(--gold-2); text-align:center; margin-bottom:12px; letter-spacing:.04em}
  html[lang=ar] .marquee-label{font-family:var(--ar); font-style:normal; font-weight:700; font-size:13px}
  .track{display:flex; gap:54px; width:max-content; animation:scroll 30s linear infinite}
  .marquee:hover .track{animation-play-state:paused}
  .track span{font-family:var(--serif); font-size:21px; font-weight:600; color:rgba(255,255,255,.55); white-space:nowrap; letter-spacing:.02em}
  html[lang=ar] .track span{font-family:var(--ar); font-weight:700; font-size:18px}
  @keyframes scroll{from{transform:translateX(0)} to{transform:translateX(-50%)}}
  html[dir=ltr] .track{animation-direction:reverse}

  /* ---------- sections ---------- */
  section.block{padding-block:88px}
  .sec-head{margin-bottom:40px; max-width:640px}
  .sec-head.center{margin-inline:auto; text-align:center}
  .sec-title{font-family:var(--ar); font-weight:900; font-size:clamp(28px,3.4vw,44px); line-height:1.15; letter-spacing:-.012em; margin:12px 0 12px}
  html[lang=en] .sec-title{font-family:var(--serif); font-weight:600; letter-spacing:.005em}
  .sec-desc{color:var(--muted); font-size:16px}
  .grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:26px}

  /* unit card */
  .card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); display:flex; flex-direction:column; transition:transform .3s ease, box-shadow .3s ease, border-color .3s}
  .card:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:var(--line-2)}
  .thumb{position:relative; aspect-ratio:16/11; overflow:hidden}
  .thumb svg{position:absolute; inset:0; width:100%; height:100%; transition:transform .6s ease}
  .card:hover .thumb svg{transform:scale(1.07)}
  .thumb::after{content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(8,28,19,.35), transparent 45%)}
  .badges{position:absolute; inset-block-start:13px; inset-inline-start:13px; display:flex; gap:7px; flex-wrap:wrap; z-index:2}
  .badge{font-size:11.5px; font-weight:800; padding:5px 11px; border-radius:999px}
  .badge-gold{background:var(--gold); color:#241a05}
  .badge-cream{background:rgba(255,253,248,.95); color:var(--clay)}
  .status{position:absolute; inset-block-start:13px; inset-inline-end:13px; z-index:2; font-size:11.5px; font-weight:800; color:#fff; padding:5px 11px; border-radius:999px; display:inline-flex; align-items:center; gap:6px}
  .status .dot{width:7px; height:7px; border-radius:50%; background:#fff}
  .card-body{padding:18px 19px 19px; display:flex; flex-direction:column; gap:13px; flex:1}
  .card-title{font-size:19px; font-weight:800; letter-spacing:-.01em; line-height:1.3}
  .card-sub{font-size:13.5px; color:var(--muted); font-weight:600; margin-top:-7px}
  .chips{display:flex; gap:7px; flex-wrap:wrap}
  .chip{font-size:12.5px; font-weight:700; color:var(--emerald-700); background:#eef4f0; border:1px solid #dceae2; padding:5px 10px; border-radius:8px}
  .card .ledger{border-top:1px solid var(--line)}
  .card-cta{display:flex; gap:8px; margin-top:auto; padding-top:4px}
  .card-cta .btn{flex:1 1 auto}

  /* journey */
  .band{background:var(--paper); border-block:1px solid var(--line)}
  .steps{display:grid; grid-template-columns:repeat(4,1fr); gap:26px}
  .step{position:relative}
  .step .num{font-family:var(--serif); font-size:34px; font-weight:600; color:var(--gold); line-height:1}
  .step .ln{height:1px; background:var(--line-2); margin:14px 0 16px; position:relative}
  .step .ln::before{content:""; position:absolute; inset-inline-start:0; top:-3px; width:7px; height:7px; border-radius:50%; background:var(--gold)}
  .step h3{font-size:18px; margin:0 0 7px; font-weight:800}
  .step p{margin:0; color:var(--muted); font-size:14.5px}

  /* dark feature blocks */
  .dark{position:relative; overflow:hidden; border-radius:26px; color:#fff; background:linear-gradient(120deg,var(--emerald-900),var(--emerald) 78%,#0f6a48); padding:52px 50px}
  .dark::after{content:""; position:absolute; inset-block:0; inset-inline-end:-40px; width:340px; background:radial-gradient(circle at 70% 50%, rgba(214,178,96,.3), transparent 62%)}
  .dark-grid{display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; position:relative; z-index:1}
  .dark h2{font-family:var(--ar); font-weight:900; font-size:clamp(26px,3vw,38px); line-height:1.18; margin:16px 0 12px; letter-spacing:-.01em}
  html[lang=en] .dark h2{font-family:var(--serif); font-weight:600}
  .dark p{color:rgba(255,255,255,.82); font-size:16px; margin:0 0 18px}
  .stat-cards{display:grid; grid-template-columns:1fr 1fr; gap:14px}
  .scard{background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.15); border-radius:16px; padding:20px}
  .scard .v{font-family:var(--serif); font-weight:600; font-size:30px; color:var(--gold-2)}
  .scard .l{color:rgba(255,255,255,.78); font-size:13.5px; font-weight:600}
  .scard.wide{grid-column:1/-1; display:flex; align-items:center; gap:11px}
  .scard.wide .l{color:#fff; font-weight:700; font-size:14.5px}

  /* lead form */
  .form-card{background:var(--paper); border-radius:18px; padding:22px; color:var(--ink)}
  .frow{display:flex; flex-direction:column; gap:6px; margin-bottom:13px}
  .frow label{font-size:13px; font-weight:700}
  .frow input,.frow select{border:1.5px solid var(--line); border-radius:12px; padding:13px 15px; font-size:14.5px; font-family:inherit; background:var(--ivory); color:var(--ink); font-weight:600}
  .frow input::placeholder{color:#9aa39d; font-weight:500}
  .frow input:focus-visible,.frow select:focus-visible{border-color:var(--gold)}
  .ferr{color:var(--clay); font-size:12.5px; font-weight:700; display:none; margin:-6px 0 8px}
  .ferr.show{display:block}
  .form-card .btn{width:100%; margin-top:4px}
  .lead-trust{display:flex; gap:9px; align-items:center; color:#fff; font-weight:700; font-size:14.5px; margin-top:4px}

  /* footer */
  footer{background:#081912; color:#c4cfc8; padding-block:54px 28px}
  .foot-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:34px; margin-bottom:34px}
  footer h4{color:#fff; font-size:15px; margin:0 0 15px; font-weight:800}
  footer .brand{color:#fff; margin-bottom:14px}
  footer p{font-size:14.5px; color:#9aa79f; max-width:34ch; margin:0 0 18px}
  .foot-links a{display:block; color:#9aa79f; font-size:14.5px; padding:5px 0; transition:color .2s} .foot-links a:hover{color:var(--gold-2)}
  .social{display:flex; gap:11px}
  .social a{width:42px; height:42px; border-radius:12px; background:rgba(255,255,255,.06); display:flex; align-items:center; justify-content:center; transition:background .25s, transform .25s}
  .social a:hover{background:var(--emerald); transform:translateY(-3px)}
  .social svg{width:19px; height:19px; color:#fff}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.1); padding-top:20px; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:13px; color:#83908a}
  .demo-tag{background:rgba(214,178,96,.16); color:var(--gold-2); border:1px solid rgba(214,178,96,.32); padding:3px 11px; border-radius:999px; font-weight:700; font-size:12px}

  /* modal + toast */
  .overlay{position:fixed; inset:0; background:rgba(8,24,17,.6); backdrop-filter:blur(4px); display:none; align-items:center; justify-content:center; z-index:300; padding:20px}
  .overlay.open{display:flex}
  .modal{background:var(--paper); border-radius:var(--r-lg); max-width:470px; width:100%; padding:28px; box-shadow:var(--shadow-lg); transform:translateY(10px); opacity:0; transition:transform .25s, opacity .25s}
  .overlay.open .modal{transform:none; opacity:1}
  .modal h3{margin:0 0 5px; font-size:22px; font-weight:800}
  .modal p{margin:0 0 18px; color:var(--muted); font-size:14.5px}
  .opt{display:flex; align-items:center; gap:13px; border:1.5px solid var(--line); border-radius:13px; padding:14px 15px; margin-bottom:10px; cursor:pointer; transition:border-color .15s, background .15s}
  .opt:hover{border-color:var(--gold); background:#faf6ec}
  .opt.sel{border-color:var(--emerald); background:#eef4f0}
  .opt input{accent-color:var(--emerald); width:18px; height:18px}
  .opt .oic{width:30px; height:30px; color:var(--emerald); flex:0 0 auto}
  .opt .ot{font-weight:700; font-size:15px} .opt .od{font-size:12.5px; color:var(--muted)}
  .modal-cta{display:flex; gap:10px; margin-top:8px}
  .modal-cta .btn{flex:1}
  .toast{position:fixed; inset-block-end:28px; inset-inline:0; margin-inline:auto; width:max-content; max-width:90vw; background:var(--emerald-900); color:#fff; padding:15px 24px; border-radius:14px; font-weight:700; font-size:14.5px; display:flex; align-items:center; gap:11px; box-shadow:var(--shadow-lg); z-index:400; opacity:0; transform:translateY(20px); transition:opacity .25s, transform .25s; pointer-events:none}
  .toast.show{opacity:1; transform:none}
  .toast .tk{width:23px; height:23px; border-radius:50%; background:var(--gold); display:flex; align-items:center; justify-content:center; flex:0 0 auto}
  .toast .tk svg{width:13px; height:13px; color:#241a05}

  /* reveal */
  .reveal{opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease}
  .reveal.in{opacity:1; transform:none}
  .reveal.d1{transition-delay:.08s} .reveal.d2{transition-delay:.16s} .reveal.d3{transition-delay:.24s}

  /* responsive */
  @media (max-width:960px){
    .slide-content{grid-template-columns:1fr; gap:30px; padding-block:130px 80px}
    .ucard{max-width:440px}
    .dark-grid{grid-template-columns:1fr; gap:26px}
    .foot-grid{grid-template-columns:1fr 1fr}
    .search{grid-template-columns:1fr 1fr}
    .search .btn{grid-column:1/-1}
    .trust-inner{grid-template-columns:1fr 1fr; gap:16px}
    .ti:nth-child(3){border-inline-start:0; padding-inline-start:0}
    .s-dots{bottom:96px}
  }
  @media (max-width:680px){
    .nav-links{display:none}
    .grid-3{grid-template-columns:1fr}
    .steps{grid-template-columns:1fr 1fr}
    .search{grid-template-columns:1fr}
    .dark{padding:34px 26px}
    .stat-cards{grid-template-columns:1fr 1fr}
    .s-arrow{display:none}
    .hero{min-height:auto}
  }
  @media (max-width:430px){ .trust-inner{grid-template-columns:1fr} .ti+.ti{border-inline-start:0; padding-inline-start:0} .steps{grid-template-columns:1fr} .foot-grid{grid-template-columns:1fr} }
  @media (prefers-reduced-motion:reduce){
    *{animation:none !important; transition-duration:.001ms !important}
    .reveal{opacity:1; transform:none}
    .slide{transition:none}
  }

  /* ====================================================================
     STAGE-1 ADDITIONS — inner pages reuse the tokens + components above.
     New class names only (no overrides of concept selectors).
     ==================================================================== */

  /* Solid header for inner pages (no hero sits behind it) */
  header.nav.solid{background:rgba(247,243,234,.96); backdrop-filter:saturate(150%) blur(12px); box-shadow:0 1px 0 var(--line); border-bottom:1px solid var(--line)}
  header.nav.solid .brand{color:var(--ink)}
  header.nav.solid .nav-links a{color:var(--muted)}
  header.nav.solid .nav-links a:hover{color:var(--ink); background:#ece4d4}
  header.nav.solid .lang{border-color:var(--line-2); color:var(--ink)}
  .nav-links a.active{color:var(--emerald); background:#ece4d4}
  header.nav:not(.scrolled):not(.solid) .nav-links a.active{color:#fff; background:rgba(255,255,255,.16)}
  body.inner{padding-top:0}

  /* Mobile nav toggle */
  .nav-toggle{display:none; align-items:center; justify-content:center; width:42px; height:42px; border-radius:10px; border:1px solid rgba(255,255,255,.28); background:transparent; color:#fff; cursor:pointer}
  header.nav.scrolled .nav-toggle, header.nav.solid .nav-toggle{color:var(--ink); border-color:var(--line-2)}
  .nav-toggle svg{width:20px; height:20px}
  @media (max-width:860px){
    .nav-links{display:none}
    .nav-toggle{display:inline-flex}
    .nav-links.open{display:flex; flex-direction:column; position:absolute; inset-block-start:76px; inset-inline:14px; background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:10px; gap:2px; box-shadow:var(--shadow-lg)}
    .nav-links.open a{color:var(--ink); font-size:15px; padding:11px 13px}
  }

  /* Inner page header band */
  .page-top{padding-top:116px; padding-bottom:30px; background:linear-gradient(180deg,#f1ead9,var(--ivory)); border-bottom:1px solid var(--line)}
  .page-top .eyebrow{color:var(--gold)}
  .page-title{font-family:var(--ar); font-weight:900; font-size:clamp(26px,3.4vw,40px); letter-spacing:-.01em; margin:6px 0 6px}
  html[lang=en] .page-title{font-family:var(--serif); font-weight:600}
  .page-lead{color:var(--muted); font-size:15.5px; max-width:60ch; margin:0}
  .crumbs{display:flex; gap:8px; align-items:center; font-size:13px; color:var(--muted); font-weight:600; margin-bottom:6px}
  .crumbs a:hover{color:var(--emerald)}
  .crumbs .sep{opacity:.5}

  /* Catalog: filter bar */
  .catalog{padding-block:30px 70px}
  .filterbar{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:16px; box-shadow:var(--shadow); display:grid; grid-template-columns:repeat(4,1fr) auto; gap:12px; align-items:end}
  .filterbar .field{display:flex; flex-direction:column; gap:6px}
  .filterbar label{font-size:12.5px; font-weight:700; color:var(--muted)}
  .filterbar select{border:1.5px solid var(--line); border-radius:11px; padding:11px 13px; font-size:14px; font-family:inherit; background:var(--ivory); color:var(--ink); font-weight:600}
  .filterbar select:focus-visible{border-color:var(--gold); outline:none}
  .filterbar .apply{height:44px}
  @media (max-width:860px){ .filterbar{grid-template-columns:1fr 1fr} .filterbar .apply{grid-column:1/-1} }
  @media (max-width:480px){ .filterbar{grid-template-columns:1fr} }

  .results-head{display:flex; justify-content:space-between; align-items:center; gap:14px; margin:26px 0 18px; flex-wrap:wrap}
  .results-count{font-weight:700; color:var(--ink)}
  .results-count .figure{color:var(--emerald)}
  .sortwrap{display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--muted); font-weight:600}
  .sortwrap select{border:1.5px solid var(--line); border-radius:10px; padding:8px 11px; font-family:inherit; font-weight:600; background:var(--paper); color:var(--ink)}

  /* Pagination */
  .pager{display:flex; gap:8px; justify-content:center; align-items:center; margin-top:42px; flex-wrap:wrap}
  .pager a, .pager span{min-width:42px; height:42px; padding:0 12px; display:inline-flex; align-items:center; justify-content:center; border-radius:11px; border:1px solid var(--line); background:var(--paper); font-weight:700; font-size:14px; color:var(--ink); transition:border-color .2s, background .2s}
  .pager a:hover{border-color:var(--gold); background:#faf6ec}
  .pager .cur{background:var(--emerald); color:#fff; border-color:var(--emerald)}
  .pager .disabled{opacity:.4; pointer-events:none}

  /* Empty state */
  .empty{text-align:center; padding:64px 24px; background:var(--paper); border:1px dashed var(--line-2); border-radius:var(--r-lg)}
  .empty .ei{width:54px; height:54px; color:var(--gold); margin:0 auto 14px}
  .empty h3{margin:0 0 8px; font-size:21px; font-weight:800}
  .empty p{margin:0 auto 18px; color:var(--muted); max-width:46ch}

  /* ===== Property detail ===== */
  .detail{padding-block:30px 70px}
  .detail-grid{display:grid; grid-template-columns:1.35fr .9fr; gap:34px; align-items:start}
  @media (max-width:900px){ .detail-grid{grid-template-columns:1fr} }
  .gallery{position:relative; border-radius:var(--r-lg); overflow:hidden; aspect-ratio:16/10; box-shadow:var(--shadow); background:var(--emerald-900)}
  .gallery svg{position:absolute; inset:0; width:100%; height:100%}
  .gallery .badges{position:absolute; inset-block-start:15px; inset-inline-start:15px; display:flex; gap:7px; flex-wrap:wrap; z-index:2}
  .gallery .status{position:absolute; inset-block-start:15px; inset-inline-end:15px; z-index:2}
  .gallery .gnote{position:absolute; inset-block-end:13px; inset-inline-start:15px; z-index:2; font-size:12px; font-weight:700; color:#fff; background:rgba(8,24,17,.5); padding:5px 11px; border-radius:999px; backdrop-filter:blur(4px)}
  .detail-title{font-family:var(--ar); font-weight:900; font-size:clamp(24px,3vw,34px); letter-spacing:-.01em; margin:18px 0 4px}
  html[lang=en] .detail-title{font-family:var(--serif); font-weight:600}
  .detail-sub{color:var(--muted); font-weight:600; font-size:15px; margin:0 0 18px}
  .specs{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:0 0 6px}
  @media (max-width:560px){ .specs{grid-template-columns:repeat(2,1fr)} }
  .spec{background:var(--paper); border:1px solid var(--line); border-radius:13px; padding:13px 15px}
  .spec .sl{font-size:12px; color:var(--muted); font-weight:700}
  .spec .sv{font-size:15.5px; font-weight:800; margin-top:2px}
  .prose{color:var(--muted); font-size:15px; line-height:1.85; margin:18px 0}

  /* Detail aside: big Clarity Ledger + plans */
  .buy-card{position:sticky; top:96px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:22px; box-shadow:var(--shadow)}
  .buy-price{display:flex; align-items:baseline; gap:10px; flex-wrap:wrap}
  .buy-price .now{font-family:var(--serif); font-weight:600; font-size:34px; color:var(--emerald)}
  .buy-price .was{font-family:var(--serif); color:var(--muted); text-decoration:line-through; font-size:20px}
  .buy-price .unit{color:var(--muted); font-weight:700; font-size:14px}
  .plan{border:1px solid var(--line); border-radius:13px; padding:13px 15px; margin-top:12px}
  .plan .plan-label{font-weight:800; font-size:14px; margin-bottom:9px; color:var(--emerald-700)}
  .plan .plan-rows{display:grid; grid-template-columns:1fr 1fr; gap:8px}
  .plan .pr{display:flex; flex-direction:column}
  .plan .pr .pk{font-size:11.5px; color:var(--muted); font-weight:700}
  .plan .pr .pv{font-size:14.5px; font-weight:800}
  .deliver-row{display:flex; justify-content:space-between; align-items:center; gap:10px; margin-top:14px; padding-top:14px; border-top:1px solid var(--line); font-weight:700}
  .deliver-row .dv{color:var(--emerald)}
  .buy-cta{display:flex; flex-direction:column; gap:9px; margin-top:16px}
  .share{display:flex; gap:9px; margin-top:14px; align-items:center; color:var(--muted); font-size:13px; font-weight:600}
  .share button{width:38px; height:38px; border-radius:10px; border:1px solid var(--line); background:var(--paper); color:var(--emerald); cursor:pointer; display:inline-flex; align-items:center; justify-content:center}
  .share button:hover{border-color:var(--gold); background:#faf6ec}
  .share svg{width:17px; height:17px}

  /* Map + developer block */
  .info-block{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:20px; margin-top:22px}
  .info-block h3{margin:0 0 12px; font-size:17px; font-weight:800}
  .map-embed{border:0; width:100%; height:300px; border-radius:14px; display:block; filter:saturate(.9)}
  .dev-row{display:flex; align-items:center; gap:14px}
  .dev-logo{width:54px; height:54px; border-radius:13px; background:linear-gradient(135deg,var(--emerald),var(--emerald-300)); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-weight:600; font-size:22px; flex:0 0 auto}
  .dev-meta .dn{font-weight:800; font-size:16px}
  .dev-meta .da{color:var(--muted); font-size:13.5px; font-weight:600}

  /* ===== Developers showcase ===== */
  .dev-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; padding-block:30px 60px}
  @media (max-width:860px){ .dev-grid{grid-template-columns:repeat(2,1fr)} }
  @media (max-width:520px){ .dev-grid{grid-template-columns:1fr} }
  .dev-card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:22px; box-shadow:var(--shadow); transition:transform .25s, box-shadow .25s}
  .dev-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-lg)}
  .dev-card .top{display:flex; align-items:center; gap:13px; margin-bottom:13px}
  .dev-card h3{margin:0; font-size:18px; font-weight:800}
  .dev-card .areas{color:var(--muted); font-size:13px; font-weight:600}
  .dev-card p{color:var(--muted); font-size:14px; margin:0 0 14px}

  /* ===== Coming-soon placeholder + setup ===== */
  .placeholder{min-height:70vh; display:flex; align-items:center; justify-content:center; text-align:center; padding:120px 24px 80px}
  .placeholder .inner-box{max-width:560px}
  .ph-mark{width:74px; height:74px; margin:0 auto 22px; border-radius:20px; background:linear-gradient(135deg,var(--emerald),var(--emerald-300)); display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow)}
  .ph-mark svg{width:36px; height:36px; color:var(--gold-2)}
  .placeholder h1{font-family:var(--ar); font-weight:900; font-size:clamp(26px,3.4vw,38px); margin:0 0 12px}
  html[lang=en] .placeholder h1{font-family:var(--serif); font-weight:600}
  .placeholder p{color:var(--muted); font-size:16px; max-width:46ch; margin:0 auto 22px}
  .ph-tag{display:inline-block; background:rgba(181,138,44,.12); color:var(--gold); border:1px solid rgba(181,138,44,.3); padding:5px 14px; border-radius:999px; font-weight:700; font-size:13px; margin-bottom:18px}

  /* About: trust explainer band reuses .dark; extra small helpers */
  .lede{font-size:18px; line-height:1.85; color:var(--ink); max-width:62ch}
  .pillrow{display:flex; gap:12px; flex-wrap:wrap; margin:22px 0}
  .pill{background:var(--paper); border:1px solid var(--line); border-radius:13px; padding:14px 18px}
  .pill .pv{font-family:var(--serif); font-weight:600; font-size:26px; color:var(--emerald)}
  .pill .pl{font-size:13px; color:var(--muted); font-weight:600}

  /* Contact layout */
  .contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:30px; padding-block:34px 70px; align-items:start}
  @media (max-width:860px){ .contact-grid{grid-template-columns:1fr} }
  .contact-card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:24px; box-shadow:var(--shadow)}
  .contact-list{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:16px}
  .contact-list li{display:flex; gap:13px; align-items:flex-start}
  .contact-list .ci{width:42px; height:42px; border-radius:12px; background:#eef4f0; color:var(--emerald); display:flex; align-items:center; justify-content:center; flex:0 0 auto}
  .contact-list .ci svg{width:20px; height:20px}
  .contact-list .ck{font-weight:800; font-size:14.5px}
  .contact-list .cv{color:var(--muted); font-size:14px}
