/*
 * BUILDKART — STYLESHEET
 * ─────────────────────────────────────────────
 * Edit this file to change colors, fonts, spacing.
 * Colors are defined as CSS variables at the top — easy to change.
 */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Inter:wght@400;500;600;700;800&display=swap');

/* ── BRAND COLORS ──────────────────────────────────────────── */
:root {
  --navy:    #0F2044;   /* Primary dark — trust & authority   */
  --navy2:   #1B3A6B;   /* Mid navy                           */
  --navy3:   #EBF0FA;   /* Light navy (bg tints)              */
  --green:   #1B7A45;   /* Primary green — growth & materials */
  --green2:  #0F5C32;   /* Dark green (hover)                 */
  --green3:  #E8F5EE;   /* Light green (bg tints)             */
  --green4:  #22A05C;   /* Accent green                       */
  --gold:    #C8953A;   /* Gold — premium & bricks            */
  --gold2:   #E8A840;   /* Light gold                         */
  --white:   #FFFFFF;
  --bg:      #F7FAF8;   /* Page background                    */
  --bg2:     #F0F6F3;   /* Section alternate background       */
  --border:  #D0DDD6;   /* Border color                       */
  --border2: #DCE6F5;   /* Border blue                        */
  --text:    #0A1C36;   /* Body text                          */
  --muted:   #637089;   /* Muted text                         */
  --muted2:  #A0AEBF;   /* Extra muted                        */
}

/* ── RESET & BASE ────────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Inter', sans-serif; background: var(--white); color: var(--text); overflow-x: hidden; line-height: 1.5; }
h1, h2, h3 { font-family: 'DM Serif Display', Georgia, serif; font-weight: 400; }
a { text-decoration: none; color: inherit; }
button { cursor: pointer; font-family: 'Inter', sans-serif; }
input, select, textarea { font-family: 'Inter', sans-serif; }
img { max-width: 100%; }

/* ── NAVIGATION ──────────────────────────────────────────── */
.nav {
  position: sticky; top: 0; z-index: 500;
  background: rgba(255,255,255,0.97); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 5%; height: 64px;
  box-shadow: 0 1px 12px rgba(15,32,68,.06);
}
.nav-logo { display: flex; align-items: center; gap: 10px; }
.nav-logo-text { font-family: 'DM Serif Display', serif; font-size: 1.3rem; color: var(--navy); letter-spacing: -.3px; }
.nav-logo-text span { color: var(--green); }
.nav-domain { font-size: .55rem; color: var(--muted2); font-weight: 700; letter-spacing: 1.8px; text-transform: uppercase; margin-top: 2px; }
.nav-links { display: flex; gap: .1rem; list-style: none; }
.nav-links a { display: block; color: var(--muted); font-size: .78rem; font-weight: 600; padding: .42rem .78rem; border-radius: 6px; transition: all .2s; }
.nav-links a:hover { background: var(--bg); color: var(--navy); }
.nav-links a.active { background: var(--navy3); color: var(--navy2); font-weight: 700; }
.nav-right { display: flex; gap: .55rem; align-items: center; }
.btn-rfq-nav { background: var(--green); color: #fff; border: none; padding: .46rem .95rem; border-radius: 7px; font-size: .78rem; font-weight: 700; transition: background .2s; }
.btn-rfq-nav:hover { background: var(--green2); }
.btn-admin-nav { background: var(--bg); color: var(--muted); border: 1px solid var(--border); padding: .46rem .85rem; border-radius: 7px; font-size: .74rem; font-weight: 600; transition: all .2s; }
.btn-admin-nav:hover { border-color: var(--navy2); color: var(--navy2); }

/* ── BUTTONS ──────────────────────────────────────────────── */
.btn-primary   { background: var(--green); color: #fff; border: none; padding: .75rem 1.5rem; border-radius: 8px; font-size: .88rem; font-weight: 700; transition: all .2s; box-shadow: 0 4px 14px rgba(27,122,69,.22); display: inline-block; }
.btn-primary:hover { background: var(--green2); transform: translateY(-1px); }
.btn-secondary { background: #fff; color: var(--navy2); border: 1.5px solid var(--border2); padding: .75rem 1.5rem; border-radius: 8px; font-size: .88rem; font-weight: 700; transition: all .2s; display: inline-block; }
.btn-secondary:hover { border-color: var(--navy2); }
.btn-outline-green { background: transparent; color: var(--green); border: 1.5px solid var(--green); padding: .75rem 1.5rem; border-radius: 8px; font-size: .88rem; font-weight: 700; transition: all .2s; display: inline-block; }
.btn-outline-green:hover { background: var(--green3); }
.btn-white  { background: #fff; color: var(--green); border: none; padding: .76rem 1.7rem; border-radius: 8px; font-size: .88rem; font-weight: 800; transition: all .2s; display: inline-block; }
.btn-white:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(0,0,0,.18); }
.btn-whatsapp { background: #25D366; color: #fff; border: none; padding: .5rem 1rem; border-radius: 6px; font-size: .78rem; font-weight: 700; transition: opacity .2s; display: inline-block; }
.btn-whatsapp:hover { opacity: .87; }
.btn-navy { background: var(--navy); color: #fff; border: none; padding: .5rem 1rem; border-radius: 6px; font-size: .78rem; font-weight: 700; transition: background .2s; display: inline-block; }
.btn-navy:hover { background: var(--navy2); }
.btn-green-sm { background: var(--green); color: #fff; border: none; padding: .45rem .9rem; border-radius: 6px; font-size: .74rem; font-weight: 700; transition: background .2s; display: inline-block; }
.btn-green-sm:hover { background: var(--green2); }

/* ── LAYOUT HELPERS ─────────────────────────────────────── */
.section       { padding: 55px 5%; }
.section-alt   { background: var(--bg); }
.section-alt2  { background: var(--bg2); }
.section-dark  { background: var(--navy); }
.container     { max-width: 1100px; margin: 0 auto; }

.sec-header    { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 1.8rem; gap: 1rem; flex-wrap: wrap; }
.eyebrow       { font-size: .66rem; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: var(--green); margin-bottom: .28rem; }
.section-title { font-size: 1.7rem; color: var(--navy); line-height: 1.2; letter-spacing: -.2px; }
.section-title-light { color: #fff; }
.section-link  { color: var(--green); font-size: .8rem; font-weight: 700; border-bottom: 1.5px solid var(--green); padding-bottom: 1px; white-space: nowrap; transition: opacity .2s; }
.section-link:hover { opacity: .7; }

.grid-2  { display: grid; grid-template-columns: 1fr 1fr;           gap: 1rem; }
.grid-3  { display: grid; grid-template-columns: 1fr 1fr 1fr;        gap: 1rem; }
.grid-4  { display: grid; grid-template-columns: repeat(4, 1fr);     gap: 1rem; }
.grid-auto { display: grid; grid-template-columns: repeat(auto-fill, minmax(295px, 1fr)); gap: 1.1rem; }
.grid-auto-sm { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1rem; }
.grid-cats { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: .75rem; }

/* ── PAGE HERO ─────────────────────────────────────────────── */
.page-hero { background: linear-gradient(135deg, #EBF4FF, #E4F5EC); padding: 36px 5%; border-bottom: 1px solid var(--border); }
.page-hero h1 { font-size: 1.85rem; color: var(--navy); margin-bottom: .28rem; }
.page-hero p  { color: var(--muted); font-size: .86rem; }

/* ── HERO (HOME) ─────────────────────────────────────────── */
.hero { background: linear-gradient(150deg, #EBF4FF 0%, #E4F5EC 45%, #FEF8EC 100%); padding: 60px 5% 68px; position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; right: -100px; top: -100px; width: 480px; height: 480px; border-radius: 50%; background: radial-gradient(circle, rgba(27,122,69,.07) 0%, transparent 65%); pointer-events: none; }
.hero-content { position: relative; max-width: 680px; }
.hero-chip { display: inline-flex; align-items: center; gap: .45rem; background: var(--green3); border: 1px solid rgba(27,122,69,.2); color: var(--green); padding: .28rem .88rem; border-radius: 20px; font-size: .7rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 1.1rem; }
.hero h1 { font-size: clamp(1.85rem, 4.5vw, 3.1rem); color: var(--navy); line-height: 1.14; margin-bottom: .8rem; letter-spacing: -.5px; }
.hero h1 em { color: var(--green); font-style: normal; }
.hero-sub { color: var(--muted); font-size: .96rem; line-height: 1.75; margin-bottom: 1.6rem; max-width: 540px; }
.trust-row { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.8rem; }
.trust-chip { display: flex; align-items: center; gap: .32rem; background: #fff; border: 1px solid var(--border); padding: .28rem .7rem; border-radius: 20px; font-size: .74rem; font-weight: 600; color: var(--text); }
.trust-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--green); flex-shrink: 0; }
.hero-btns { display: flex; gap: .7rem; flex-wrap: wrap; margin-bottom: 2.5rem; }
.hero-stats { display: flex; gap: 2.2rem; flex-wrap: wrap; }
.stat-num { font-family: 'DM Serif Display', serif; font-size: 1.85rem; color: var(--navy); line-height: 1; }
.stat-label { font-size: .66rem; color: var(--muted2); text-transform: uppercase; letter-spacing: 1px; margin-top: .15rem; font-weight: 500; }

/* ── SEARCH BAR ──────────────────────────────────────────── */
.search-section { background: #fff; padding: 1.2rem 5%; border-bottom: 1px solid var(--border); box-shadow: 0 2px 8px rgba(15,32,68,.04); }
.search-bar { display: flex; max-width: 800px; border-radius: 9px; overflow: hidden; border: 2px solid var(--green); box-shadow: 0 4px 20px rgba(27,122,69,.1); }
.search-select { background: var(--bg); color: var(--navy2); border: none; border-right: 2px solid var(--green); padding: 0 .9rem; font-size: .82rem; font-weight: 600; min-width: 150px; outline: none; }
.search-input  { flex: 1; border: none; padding: .85rem .95rem; font-size: .88rem; outline: none; color: var(--text); }
.search-btn    { background: var(--green); color: #fff; border: none; padding: 0 1.4rem; font-size: .86rem; font-weight: 700; }
.search-btn:hover { background: var(--green2); }

/* ── PRICE TABLE ──────────────────────────────────────────── */
.price-cats { display: flex; gap: .45rem; overflow-x: auto; scrollbar-width: none; padding: .1rem 0 1rem; }
.price-cats::-webkit-scrollbar { display: none; }
.price-cat-btn { display: flex; align-items: center; gap: .38rem; padding: .48rem 1rem; border-radius: 7px; border: 1.5px solid var(--border); background: #fff; color: var(--muted); font-size: .78rem; font-weight: 600; transition: all .2s; white-space: nowrap; cursor: pointer; }
.price-cat-btn:hover { border-color: var(--green); color: var(--green); }
.price-cat-btn.active { background: var(--green); color: #fff; border-color: var(--green); }
.updated-badge { display: inline-flex; align-items: center; gap: .38rem; background: var(--green3); border: 1px solid rgba(27,122,69,.15); color: var(--green); padding: .26rem .72rem; border-radius: 20px; font-size: .7rem; font-weight: 600; margin-bottom: 1.1rem; }
.price-table { width: 100%; border-collapse: collapse; background: #fff; border-radius: 10px; overflow: hidden; border: 1px solid var(--border); }
.price-table th { background: var(--navy); color: rgba(255,255,255,.75); padding: .76rem 1rem; text-align: left; font-size: .67rem; letter-spacing: 1px; text-transform: uppercase; font-weight: 600; }
.price-table td { padding: .78rem 1rem; border-bottom: 1px solid var(--border); font-size: .84rem; }
.price-table tr:last-child td { border-bottom: none; }
.price-table tr:hover td { background: #F4FAF7; }
.price-val { font-family: 'DM Serif Display', serif; color: var(--navy2); font-size: .92rem; }
.price-unit { font-size: .7rem; color: var(--muted2); }
.trend-up   { color: #C0392B; font-size: .74rem; font-weight: 700; }
.trend-down { color: var(--green); font-size: .74rem; font-weight: 700; }
.trend-stable { color: var(--muted2); font-size: .74rem; font-weight: 700; }
.table-wrap { overflow-x: auto; }

/* ── CATEGORY GRID ─────────────────────────────────────────── */
.cat-card { background: #fff; border: 1.5px solid var(--border); border-radius: 10px; padding: .9rem .65rem; text-align: center; cursor: pointer; transition: all .22s; }
.cat-card:hover { border-color: var(--green); box-shadow: 0 4px 14px rgba(27,122,69,.1); transform: translateY(-2px); }
.cat-icon  { font-size: 1.45rem; margin-bottom: .38rem; }
.cat-name  { font-size: .73rem; font-weight: 700; color: var(--navy); }
.cat-count { font-size: .63rem; color: var(--muted2); margin-top: .08rem; }

/* ── SUPPLIER CARDS ─────────────────────────────────────────── */
.supplier-card { background: #fff; border-radius: 12px; border: 1px solid var(--border); padding: 1.2rem; transition: all .25s; position: relative; }
.supplier-card:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(15,32,68,.09); border-color: var(--border2); }
.supplier-card.featured { border-color: var(--gold); border-width: 1.5px; }
.featured-ribbon { position: absolute; top: -1px; right: 12px; background: var(--gold); color: #fff; font-size: .6rem; font-weight: 800; padding: .15rem .5rem; border-radius: 0 0 5px 5px; }
.sup-top { display: flex; gap: .8rem; margin-bottom: .8rem; align-items: flex-start; }
.sup-emoji { width: 48px; height: 48px; border-radius: 9px; background: var(--bg2); display: flex; align-items: center; justify-content: center; font-size: 1.35rem; flex-shrink: 0; }
.sup-name { font-weight: 700; font-size: .88rem; color: var(--navy); margin-bottom: .22rem; line-height: 1.3; }
.sup-badges { display: flex; gap: .28rem; flex-wrap: wrap; margin-bottom: .22rem; }
.badge-verified { background: var(--green3); color: var(--green); font-size: .62rem; font-weight: 800; padding: .14rem .44rem; border-radius: 4px; border: 1px solid rgba(27,122,69,.2); }
.badge-gst      { background: #E8F0FF; color: #1B5FAA; font-size: .62rem; font-weight: 700; padding: .14rem .44rem; border-radius: 4px; }
.badge-featured { background: #FFF3DC; color: var(--gold); font-size: .62rem; font-weight: 800; padding: .14rem .44rem; border-radius: 4px; }
.badge-premium  { background: var(--green3); color: var(--green); font-size: .62rem; font-weight: 800; padding: .14rem .44rem; border-radius: 4px; }
.badge-standard { background: var(--navy3); color: var(--navy2); font-size: .62rem; font-weight: 800; padding: .14rem .44rem; border-radius: 4px; }
.badge-free     { background: #F5F5F5; color: #888; font-size: .62rem; font-weight: 800; padding: .14rem .44rem; border-radius: 4px; }
.sup-meta { font-size: .74rem; color: var(--muted); }
.sup-info { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: .7rem; font-size: .7rem; color: var(--muted); }
.sup-brands { display: flex; gap: .25rem; flex-wrap: wrap; margin-bottom: .8rem; }
.brand-chip { background: var(--navy3); color: var(--navy2); font-size: .64rem; font-weight: 700; padding: .14rem .42rem; border-radius: 3px; }
.sup-actions { display: grid; grid-template-columns: 1fr 1fr; gap: .4rem; border-top: 1px solid var(--border); padding-top: .75rem; }
.sup-actions .btn-view { grid-column: span 2; background: var(--bg); color: var(--navy); border: 1px solid var(--border); padding: .4rem; border-radius: 6px; font-size: .7rem; font-weight: 600; text-align: center; transition: all .2s; }
.sup-actions .btn-view:hover { background: var(--navy3); color: var(--navy2); }

/* ── PROPERTY CARDS ─────────────────────────────────────────── */
.property-card { background: #fff; border-radius: 12px; overflow: hidden; border: 1px solid var(--border); transition: all .25s; }
.property-card:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(15,32,68,.09); }
.prop-img { height: 155px; display: flex; align-items: center; justify-content: center; font-size: 2.8rem; position: relative; }
.prop-type-badge { position: absolute; top: 9px; left: 9px; padding: .2rem .52rem; border-radius: 4px; font-size: .63rem; font-weight: 800; text-transform: uppercase; }
.badge-sale { background: var(--navy2); color: #fff; }
.badge-plot { background: var(--gold); color: #fff; }
.prop-body { padding: .95rem; }
.prop-price { font-family: 'DM Serif Display', serif; font-size: 1.15rem; color: var(--navy); }
.prop-title { font-size: .85rem; font-weight: 700; margin: .26rem 0; color: var(--text); }
.prop-loc   { font-size: .72rem; color: var(--muted); margin-bottom: .78rem; }
.prop-feats { display: flex; gap: .75rem; border-top: 1px solid var(--border); padding-top: .68rem; margin-bottom: .78rem; }
.prop-feat  { font-size: .7rem; color: var(--muted); }
.prop-cta   { display: block; width: 100%; background: var(--green); color: #fff; border: none; padding: .48rem; border-radius: 6px; font-size: .76rem; font-weight: 700; text-align: center; cursor: pointer; transition: background .2s; }
.prop-cta:hover { background: var(--green2); }

/* ── SERVICE CARDS ─────────────────────────────────────────── */
.service-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 1.2rem; transition: all .25s; }
.service-card:hover { border-color: var(--green); box-shadow: 0 5px 20px rgba(27,122,69,.09); transform: translateY(-2px); }
.svc-icon-wrap { width: 46px; height: 46px; border-radius: 10px; background: var(--green3); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; margin-bottom: .75rem; }
.svc-name { font-weight: 700; font-size: .9rem; color: var(--navy); margin-bottom: .28rem; }
.svc-desc { font-size: .76rem; color: var(--muted); line-height: 1.6; margin-bottom: .55rem; }
.svc-area { font-size: .68rem; color: var(--green); font-weight: 600; margin-bottom: .85rem; }
.svc-btn  { display: block; width: 100%; background: var(--navy); color: #fff; border: none; padding: .48rem; border-radius: 6px; font-size: .76rem; font-weight: 700; text-align: center; cursor: pointer; transition: background .2s; }
.svc-btn:hover { background: var(--green); }

/* ── TABS ────────────────────────────────────────────────── */
.tabs { display: flex; background: var(--bg); border-radius: 8px; padding: .26rem; gap: .18rem; width: fit-content; margin-bottom: 1.5rem; }
.tab-btn { padding: .45rem 1rem; font-size: .78rem; font-weight: 600; border: none; background: transparent; color: var(--muted); border-radius: 6px; cursor: pointer; transition: all .2s; }
.tab-btn.active { background: #fff; color: var(--navy2); box-shadow: 0 1px 5px rgba(15,32,68,.09); font-weight: 700; }

/* ── WHY SECTION ─────────────────────────────────────────── */
.why-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(195px, 1fr)); gap: 1.1rem; margin-top: 1.4rem; }
.why-card { padding: 1.3rem; border-radius: 10px; background: var(--bg); border: 1px solid var(--border); transition: all .2s; }
.why-card:hover { border-color: var(--green); box-shadow: 0 3px 14px rgba(27,122,69,.07); }
.why-icon  { font-size: 1.5rem; margin-bottom: .6rem; }
.why-title { font-weight: 700; font-size: .86rem; color: var(--navy); margin-bottom: .28rem; }
.why-text  { font-size: .76rem; color: var(--muted); line-height: 1.65; }

/* ── RFQ BANNER ─────────────────────────────────────────── */
.rfq-banner { background: linear-gradient(135deg, var(--navy) 0%, var(--navy2) 100%); padding: 48px 5%; display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; position: relative; overflow: hidden; }
.rfq-banner::after { content: ''; position: absolute; right: -55px; top: -55px; width: 260px; height: 260px; border-radius: 50%; background: rgba(27,122,69,.15); pointer-events: none; }
.rfq-banner h2 { font-size: 1.7rem; color: #fff; letter-spacing: -.2px; }
.rfq-banner p  { color: rgba(255,255,255,.5); margin-top: .32rem; font-size: .84rem; }

/* ── CALCULATOR ─────────────────────────────────────────── */
.calc-tabs { display: flex; gap: .45rem; flex-wrap: wrap; margin-bottom: 1.3rem; }
.calc-tab  { padding: .48rem 1rem; border-radius: 7px; border: 1.5px solid var(--border); background: #fff; color: var(--muted); font-size: .78rem; font-weight: 700; cursor: pointer; transition: all .2s; }
.calc-tab:hover { border-color: var(--green); color: var(--green); }
.calc-tab.active { background: var(--green); color: #fff; border-color: var(--green); }
.calc-box  { background: #fff; border-radius: 12px; border: 1px solid var(--border); padding: 1.8rem; }
.calc-label { font-size: .72rem; font-weight: 700; color: var(--navy2); text-transform: uppercase; letter-spacing: .5px; margin-bottom: .38rem; display: block; }
.calc-input { width: 100%; border: 1.5px solid var(--border); border-radius: 8px; padding: .72rem .95rem; font-size: .92rem; color: var(--text); outline: none; margin-bottom: 1rem; transition: border-color .2s; }
.calc-input:focus { border-color: var(--green); }
.calc-result { background: var(--green3); border: 1px solid rgba(27,122,69,.18); border-radius: 10px; padding: 1.1rem; margin: 1.1rem 0; display: none; }
.calc-result.visible { display: block; }
.calc-result-title { font-size: .7rem; color: var(--green); font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: .38rem; }
.calc-result-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .7rem; margin-bottom: .65rem; }
.calc-result-item { background: #fff; border-radius: 7px; padding: .75rem; border: 1px solid rgba(27,122,69,.1); }
.calc-result-val  { font-family: 'DM Serif Display', serif; font-size: 1.4rem; color: var(--navy); line-height: 1; }
.calc-result-lbl  { font-size: .68rem; color: var(--muted); margin-top: .18rem; }
.calc-note { font-size: .7rem; color: var(--muted); line-height: 1.6; }
.calc-ref-item { display: flex; gap: .85rem; align-items: center; background: #fff; border: 1px solid var(--border); border-radius: 9px; padding: .85rem; margin-bottom: .5rem; }
.calc-ref-mat  { font-weight: 700; font-size: .86rem; color: var(--navy); }
.calc-ref-rate { font-size: .8rem; color: var(--green); font-weight: 600; }

/* ── MODALS ─────────────────────────────────────────────── */
.modal-overlay { position: fixed; inset: 0; background: rgba(8,18,36,.75); z-index: 900; display: none; align-items: center; justify-content: center; backdrop-filter: blur(5px); }
.modal-overlay.open { display: flex; }
.modal-box { background: #fff; border-radius: 14px; width: 96%; max-width: 510px; max-height: 92vh; overflow-y: auto; box-shadow: 0 24px 64px rgba(0,0,0,.3); }
.modal-header { background: linear-gradient(135deg, var(--green), var(--green2)); padding: 1.1rem 1.4rem; display: flex; align-items: center; justify-content: space-between; border-radius: 14px 14px 0 0; position: sticky; top: 0; }
.modal-header h3 { color: #fff; font-size: 1.1rem; font-family: 'DM Serif Display', serif; }
.modal-close { background: rgba(255,255,255,.15); border: none; color: #fff; width: 27px; height: 27px; border-radius: 50%; font-size: .88rem; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.modal-body { padding: 1.4rem; }
.modal-note { background: var(--green3); border: 1px solid rgba(27,122,69,.15); border-radius: 7px; padding: .7rem .95rem; font-size: .76rem; color: #0F5C32; margin-bottom: 1.1rem; line-height: 1.6; }

/* ── FORM ELEMENTS ───────────────────────────────────────── */
.form-row  { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; }
.form-group { margin-bottom: .85rem; }
.form-group label { display: block; font-size: .7rem; font-weight: 700; margin-bottom: .28rem; color: var(--navy2); text-transform: uppercase; letter-spacing: .4px; }
.form-group input,
.form-group select,
.form-group textarea { width: 100%; border: 1.5px solid var(--border); border-radius: 6px; padding: .58rem .82rem; font-size: .86rem; color: var(--text); outline: none; transition: border-color .2s; background: #fff; }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color: var(--green); }
.form-submit { width: 100%; background: var(--green); color: #fff; border: none; padding: .75rem; border-radius: 8px; font-size: .9rem; font-weight: 700; margin-top: .4rem; cursor: pointer; transition: background .2s; }
.form-submit:hover { background: var(--green2); }
.form-note { font-size: .7rem; color: var(--muted2); text-align: center; margin-top: .55rem; }

/* ── SUCCESS STATE ─────────────────────────────────────── */
.success-state { text-align: center; padding: 2rem 1.4rem; }
.success-icon  { font-size: 2.8rem; margin-bottom: .9rem; }
.success-state h3 { font-size: 1.35rem; color: var(--navy); margin-bottom: .45rem; font-family: 'DM Serif Display', serif; }
.success-state p  { font-size: .83rem; color: var(--muted); line-height: 1.7; }

/* ── ADMIN PANEL ─────────────────────────────────────────── */
.admin-modal .modal-box { max-width: 920px; }
.admin-modal .modal-header { background: var(--navy); }
.admin-tabs { display: flex; border-bottom: 1px solid var(--border); overflow-x: auto; }
.admin-tab  { padding: .72rem 1.1rem; font-size: .75rem; font-weight: 700; border: none; background: transparent; color: var(--muted); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all .2s; white-space: nowrap; cursor: pointer; }
.admin-tab.active { color: var(--green); border-bottom-color: var(--green); }
.admin-body { padding: 1.3rem; }
.admin-section { background: var(--bg); border: 1px solid var(--border); border-radius: 9px; padding: 1.1rem; margin-bottom: 1.1rem; }
.admin-section-title { font-size: .68rem; font-weight: 800; text-transform: uppercase; letter-spacing: .8px; color: var(--muted); margin-bottom: .85rem; }
.admin-list { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1rem; }
.admin-row  { display: flex; align-items: center; justify-content: space-between; background: #fff; border: 1px solid var(--border); border-radius: 7px; padding: .65rem .88rem; gap: .7rem; }
.admin-row-name  { font-weight: 700; font-size: .83rem; color: var(--text); }
.admin-row-sub   { font-size: .7rem; color: var(--muted); margin-top: .07rem; }
.admin-row-price { font-weight: 800; color: var(--navy2); font-size: .86rem; flex-shrink: 0; }
.btn-delete { background: rgba(192,57,43,.07); color: #C0392B; border: none; border-radius: 5px; padding: .26rem .58rem; font-size: .7rem; font-weight: 700; cursor: pointer; white-space: nowrap; }
.btn-delete:hover { background: #C0392B; color: #fff; }
.btn-add    { background: var(--green); color: #fff; border: none; padding: .58rem 1.15rem; border-radius: 6px; font-size: .8rem; font-weight: 700; cursor: pointer; display: inline-flex; align-items: center; gap: .32rem; }
.btn-add:hover { background: var(--green2); }
.btn-save   { background: var(--navy2); color: #fff; border: none; padding: .58rem 1.15rem; border-radius: 6px; font-size: .8rem; font-weight: 700; margin-left: .48rem; cursor: pointer; }

/* ── RFQ ITEM (ADMIN) ───────────────────────────────────── */
.rfq-item { background: #fff; border: 1px solid var(--border); border-radius: 9px; padding: .9rem; margin-bottom: .6rem; }
.rfq-item-top { display: flex; justify-content: space-between; margin-bottom: .5rem; }
.rfq-material { font-weight: 700; font-size: .88rem; color: var(--navy); }
.rfq-details  { font-size: .76rem; color: var(--muted); }
.rfq-status-new  { background: #FEF3D4; color: var(--gold); font-size: .65rem; font-weight: 800; padding: .17rem .5rem; border-radius: 4px; white-space: nowrap; }
.rfq-status-done { background: var(--green3); color: var(--green); font-size: .65rem; font-weight: 800; padding: .17rem .5rem; border-radius: 4px; white-space: nowrap; }
.rfq-contact { font-size: .76rem; color: var(--muted); display: flex; gap: .85rem; flex-wrap: wrap; margin-bottom: .65rem; }
.rfq-actions { display: flex; gap: .45rem; }

/* ── LOGIN BOX ──────────────────────────────────────────── */
.login-box  { background: #fff; border-radius: 14px; padding: 2.2rem; max-width: 355px; width: 90%; box-shadow: 0 24px 64px rgba(0,0,0,.4); }
.login-sub  { font-size: .78rem; color: var(--muted); margin: .28rem 0 1.4rem; }
.login-error { background: #FDF2F2; color: #C0392B; border: 1px solid rgba(192,57,43,.2); padding: .5rem .8rem; border-radius: 6px; font-size: .76rem; font-weight: 600; margin-bottom: .8rem; display: none; }
.login-error.show { display: block; }

/* ── SUPPLIER DETAIL ─────────────────────────────────────── */
.sup-detail-hero { background: linear-gradient(135deg, #EBF4FF, #E4F5EC); padding: 1.8rem 5%; border-bottom: 1px solid var(--border); }
.sup-detail-top  { display: flex; gap: 1.1rem; flex-wrap: wrap; align-items: flex-start; }
.sup-detail-emoji { width: 66px; height: 66px; border-radius: 13px; background: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.8rem; border: 2px solid var(--border); flex-shrink: 0; }
.sup-detail-actions { display: flex; flex-direction: column; gap: .45rem; min-width: 140px; }
.sup-detail-actions a,
.sup-detail-actions button { width: 100%; text-align: center; }
.info-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: .7rem; margin-top: 1.1rem; }
.info-item { background: #fff; border-radius: 8px; padding: .7rem .9rem; border: 1px solid var(--border); }
.info-label { font-size: .62rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--muted2); margin-bottom: .18rem; }
.info-value { font-size: .85rem; font-weight: 700; color: var(--navy); }
.product-item { display: flex; align-items: center; justify-content: space-between; background: var(--bg); border: 1px solid var(--border); border-radius: 7px; padding: .62rem .9rem; margin-bottom: .45rem; }
.product-name { font-size: .83rem; font-weight: 600; color: var(--navy); }

/* ── TOAST ───────────────────────────────────────────────── */
.toast { position: fixed; bottom: 1.1rem; right: 1.1rem; background: var(--green); color: #fff; padding: .6rem 1.1rem; border-radius: 8px; font-size: .78rem; font-weight: 700; box-shadow: 0 6px 20px rgba(27,122,69,.3); z-index: 9999; transform: translateY(100px); opacity: 0; transition: all .3s ease; pointer-events: none; }
.toast.show { transform: translateY(0); opacity: 1; }

/* ── FOOTER ──────────────────────────────────────────────── */
footer { background: var(--navy); padding: 44px 5% 22px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2.2rem; margin-bottom: 2rem; }
.footer-desc  { font-size: .76rem; color: rgba(255,255,255,.25); line-height: 1.75; margin-top: .65rem; }
.footer-logo-text { font-family: 'DM Serif Display', serif; font-size: 1.3rem; color: #fff; letter-spacing: -.3px; }
.footer-logo-text span { color: var(--green4); }
.footer-col h4 { color: rgba(255,255,255,.25); font-size: .63rem; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: .75rem; }
.footer-col a  { display: block; color: rgba(255,255,255,.2); font-size: .76rem; margin-bottom: .38rem; transition: color .2s; }
.footer-col a:hover { color: var(--gold2); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.06); padding-top: 1.05rem; display: flex; justify-content: space-between; font-size: .7rem; color: rgba(255,255,255,.14); flex-wrap: wrap; gap: .4rem; }
.footer-bottom span:last-child { color: rgba(200,149,58,.38); }

/* ── EMPTY STATE ─────────────────────────────────────────── */
.empty-state { text-align: center; padding: 3rem 2rem; color: var(--muted); }
.empty-state-icon { font-size: 2.5rem; margin-bottom: .8rem; }
.empty-state h3 { font-size: 1.1rem; color: var(--navy); margin-bottom: .4rem; }
.empty-state p  { font-size: .84rem; }

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width: 768px) {
  .nav-links { display: none; }
  .section   { padding: 40px 5%; }
  .hero      { padding: 40px 5% 48px; }
  .hero h1   { font-size: 1.8rem; }
  .hero-btns { flex-direction: column; }
  .btn-primary, .btn-secondary, .btn-outline-green { width: 100%; text-align: center; }
  .hero-stats { gap: 1.3rem; }
  .grid-auto, .grid-auto-sm { grid-template-columns: 1fr; }
  .grid-2, .form-row { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .rfq-banner { flex-direction: column; text-align: center; }
  .btn-white  { width: 100%; }
  .why-grid   { grid-template-columns: 1fr 1fr; }
  .sec-header { flex-direction: column; align-items: flex-start; }
  .modal-box  { max-height: 96vh; }
  .info-grid  { grid-template-columns: 1fr 1fr; }
  .calc-result-grid { grid-template-columns: 1fr; }
  .sup-detail-actions { width: 100%; flex-direction: row; flex-wrap: wrap; }
  .sup-detail-actions a,
  .sup-detail-actions button { flex: 1; }
}
@media (max-width: 480px) {
  .why-grid, .grid-auto-sm { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .grid-cats   { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); }
  .admin-modal .modal-box { max-height: 98vh; }
  .sup-detail-top { flex-direction: column; }
  .info-grid  { grid-template-columns: 1fr; }
}


/* ── CITY SELECTOR ─────────────────────────────────────────── */
.city-selector{display:flex;align-items:center;gap:.4rem;background:var(--green3);border:1px solid rgba(27,122,69,.2);color:var(--green);padding:.32rem .78rem;border-radius:20px;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .2s;position:relative;user-select:none;}
.city-selector:hover{background:var(--green);color:#fff;}
.city-dropdown{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(15,32,68,.12);min-width:220px;z-index:600;display:none;overflow:hidden;}
.city-dropdown.open{display:block;}
.city-option{padding:.65rem 1rem;font-size:.82rem;cursor:pointer;display:flex;align-items:center;gap:.6rem;transition:background .15s;}
.city-option:hover{background:var(--bg);}
.city-option.live{color:var(--navy);font-weight:600;}
.city-option.soon{color:var(--muted2);cursor:default;}
.city-option.soon:hover{background:transparent;}
.city-live-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0;}
.city-soon-dot{width:7px;height:7px;border-radius:50%;background:var(--muted2);flex-shrink:0;}
.city-serving{font-size:.7rem;color:var(--muted2);background:var(--bg);padding:.38rem 1rem;border-top:1px solid var(--border);}

/* ── SUPPLIER DETAIL PAGE ───────────────────────────────────── */
.sup-hero{background:linear-gradient(135deg,#EBF4FF,#E4F5EC);padding:2rem 5%;border-bottom:1px solid var(--border);}
.sup-hero-top{display:flex;gap:1.2rem;flex-wrap:wrap;align-items:flex-start;}
.sup-hero-emoji{width:72px;height:72px;border-radius:14px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;border:2px solid var(--border);flex-shrink:0;}
.sup-hero-info{flex:1;min-width:200px;}
.sup-hero-actions{display:flex;flex-direction:column;gap:.5rem;min-width:150px;}
.sup-hero-actions a,.sup-hero-actions button{width:100%;text-align:center;display:block;}
.sup-info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.7rem;margin-top:1.2rem;}
.sup-info-item{background:#fff;border-radius:8px;padding:.7rem .9rem;border:1px solid var(--border);}
.sup-info-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted2);margin-bottom:.15rem;}
.sup-info-value{font-size:.84rem;font-weight:700;color:var(--navy);}
.delivery-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.8rem;}
.del-badge{display:flex;align-items:center;gap:.32rem;background:var(--green3);border:1px solid rgba(27,122,69,.15);color:var(--green);padding:.28rem .68rem;border-radius:20px;font-size:.72rem;font-weight:600;}
.brand-pill{display:inline-block;background:var(--n3);color:var(--navy2);font-size:.76rem;font-weight:700;padding:.32rem .75rem;border-radius:6px;margin:.2rem .2rem .2rem 0;cursor:pointer;border:1.5px solid transparent;transition:all .2s;}
.brand-pill:hover{border-color:var(--green);color:var(--green);}
.best-for-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.4rem;}
.best-for-tag{background:var(--bg2);border:1px solid var(--border);color:var(--navy);font-size:.74rem;font-weight:600;padding:.28rem .7rem;border-radius:5px;display:flex;align-items:center;gap:.3rem;}
.product-list{display:flex;flex-direction:column;gap:.5rem;}
.product-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:.65rem .95rem;}
.product-name{font-size:.83rem;font-weight:600;color:var(--navy);}
.product-price{font-family:"DM Serif Display",serif;font-size:.95rem;color:var(--navy2);margin:0 .8rem;}
.review-placeholder{text-align:center;padding:2rem;background:var(--bg);border-radius:9px;border:1px dashed var(--border);}

/* ── PROPERTY DETAIL ────────────────────────────────────────── */
.prop-hero{background:linear-gradient(135deg,#EBF4FF,#E4F5EC);padding:2rem 5%;border-bottom:1px solid var(--border);}
.prop-price-big{font-family:"DM Serif Display",serif;font-size:2rem;color:var(--navy);}
.prop-psqft{font-size:.82rem;color:var(--muted);margin-left:.5rem;}
.prop-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
.amenity-list{display:flex;flex-wrap:wrap;gap:.5rem;}
.amenity-tag{background:var(--green3);color:var(--green);border:1px solid rgba(27,122,69,.15);font-size:.73rem;font-weight:600;padding:.28rem .68rem;border-radius:5px;}
.rera-badge{display:inline-flex;align-items:center;gap:.35rem;background:#E8F0FF;color:#1B5FAA;border:1px solid rgba(27,90,170,.15);font-size:.72rem;font-weight:700;padding:.28rem .68rem;border-radius:5px;}
.vastu-yes{background:var(--green3);color:var(--green);font-size:.72rem;font-weight:700;padding:.28rem .68rem;border-radius:5px;}
.vastu-no{background:#FDF2F2;color:#C0392B;font-size:.72rem;font-weight:700;padding:.28rem .68rem;border-radius:5px;}
.loan-badge{background:#FFF3DC;color:var(--gold);font-size:.72rem;font-weight:700;padding:.28rem .68rem;border-radius:5px;}
.nearby-item{font-size:.8rem;color:var(--muted);padding:.4rem 0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;}
.nearby-item:last-child{border-bottom:none;}

/* ── EMI CALCULATOR ─────────────────────────────────────────── */
.emi-box{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:1.5rem;}
.emi-result{background:var(--navy);border-radius:10px;padding:1.2rem;margin-top:1rem;text-align:center;}
.emi-amount{font-family:"DM Serif Display",serif;font-size:2rem;color:#fff;line-height:1;}
.emi-label{font-size:.72rem;color:rgba(255,255,255,.5);margin-top:.3rem;}
.emi-breakdown{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-top:.9rem;}
.emi-break-item{background:rgba(255,255,255,.06);border-radius:7px;padding:.7rem;text-align:center;}
.emi-break-val{font-family:"DM Serif Display",serif;font-size:1.1rem;color:#fff;}
.emi-break-lbl{font-size:.66rem;color:rgba(255,255,255,.45);margin-top:.15rem;}

/* ── BUILDKART PROJECT ──────────────────────────────────────── */
.project-hero{background:linear-gradient(135deg,var(--navy),var(--navy2));padding:48px 5%;color:#fff;position:relative;overflow:hidden;}
.project-hero::after{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;background:rgba(27,122,69,.2);pointer-events:none;}
.project-stages{display:flex;flex-direction:column;gap:.75rem;}
.stage-card{background:#fff;border:1.5px solid var(--border);border-radius:12px;overflow:hidden;transition:all .2s;}
.stage-card.active{border-color:var(--green);box-shadow:0 4px 20px rgba(27,122,69,.12);}
.stage-header{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.3rem;cursor:pointer;}
.stage-num{width:28px;height:28px;border-radius:50%;background:var(--bg);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:var(--muted);flex-shrink:0;}
.stage-card.active .stage-num{background:var(--green);border-color:var(--green);color:#fff;}
.stage-card.done .stage-num{background:var(--green3);border-color:var(--green);color:var(--green);}
.stage-icon{font-size:1.3rem;}
.stage-name{font-weight:700;font-size:.92rem;color:var(--navy);}
.stage-desc{font-size:.74rem;color:var(--muted);}
.stage-chevron{margin-left:auto;color:var(--muted2);transition:transform .2s;}
.stage-card.active .stage-chevron{transform:rotate(90deg);}
.stage-body{display:none;padding:0 1.3rem 1.3rem;}
.stage-card.active .stage-body{display:block;}
.stage-materials{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.9rem;}
.mat-tag{background:var(--green3);color:var(--green);border:1px solid rgba(27,122,69,.15);font-size:.73rem;font-weight:600;padding:.25rem .65rem;border-radius:5px;cursor:pointer;transition:all .2s;}
.mat-tag:hover{background:var(--green);color:#fff;}
.stage-tip{background:rgba(200,149,58,.08);border:1px solid rgba(200,149,58,.2);border-radius:7px;padding:.7rem .9rem;font-size:.74rem;color:#855A00;line-height:1.65;margin-top:.6rem;}
.project-card{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:1.2rem;transition:all .25s;}
.project-card:hover{border-color:var(--green);box-shadow:0 4px 16px rgba(27,122,69,.1);}
.progress-bar{height:6px;background:var(--bg2);border-radius:3px;overflow:hidden;margin:.6rem 0;}
.progress-fill{height:100%;background:linear-gradient(to right,var(--green),var(--green4));border-radius:3px;transition:width .4s;}

/* ── BRAND FILTER PAGE ──────────────────────────────────────── */
.brand-hero{background:linear-gradient(135deg,#EBF4FF,#E4F5EC);padding:2rem 5%;border-bottom:1px solid var(--border);}
.brand-logo-big{font-size:2rem;font-weight:800;color:var(--navy);font-family:"DM Serif Display",serif;}

/* ── ARTICLES ───────────────────────────────────────────────── */
.article-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:1.3rem;transition:all .25s;cursor:pointer;}
.article-card:hover{border-color:var(--green);box-shadow:0 4px 16px rgba(27,122,69,.08);transform:translateY(-2px);}
.article-cat{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--green);margin-bottom:.4rem;}
.article-title{font-family:"DM Serif Display",serif;font-size:1.1rem;color:var(--navy);margin-bottom:.4rem;line-height:1.35;}
.article-summary{font-size:.78rem;color:var(--muted);line-height:1.65;margin-bottom:.6rem;}
.article-meta{font-size:.68rem;color:var(--muted2);}

/* ── STATS BAR (hidden by default) ─────────────────────────── */
.stats-bar{background:var(--navy3);border:1px solid var(--border2);border-radius:10px;padding:.9rem 1.2rem;display:flex;gap:1.5rem;flex-wrap:wrap;align-items:center;margin-bottom:1.5rem;}
.stat-item{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--navy2);font-weight:600;}
.stat-item-num{font-family:"DM Serif Display",serif;font-size:1.1rem;color:var(--navy);}

/* ── PRICE TREND ROW ────────────────────────────────────────── */
.trend-row{display:flex;gap:1.2rem;align-items:baseline;flex-wrap:wrap;}
.trend-this{font-family:"DM Serif Display",serif;font-size:1rem;color:var(--navy2);}
.trend-last{font-size:.72rem;color:var(--muted);}
.trend-pct{font-size:.7rem;font-weight:700;padding:.1rem .38rem;border-radius:3px;}
.trend-pct-up{background:#FEE;color:#C0392B;}
.trend-pct-dn{background:var(--green3);color:var(--green);}
.trend-pct-st{background:var(--bg2);color:var(--muted2);}

/* ── OPEN/CLOSED INDICATOR ──────────────────────────────────── */
.open-now{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:700;color:var(--green);}
.open-now::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green);display:inline-block;}
.closed-now{color:#C0392B;}
.closed-now::before{background:#C0392B;}

/* ── RESPONSIVE ADDITIONS ───────────────────────────────────── */
@media(max-width:768px){
  .prop-detail-grid{grid-template-columns:1fr;}
  .sup-hero-actions{flex-direction:row;flex-wrap:wrap;}
  .sup-hero-actions a,.sup-hero-actions button{flex:1;min-width:130px;}
  .project-stages{gap:.5rem;}
  .emi-breakdown{grid-template-columns:1fr;}
  .sup-info-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){
  .sup-info-grid,.emi-breakdown{grid-template-columns:1fr;}
  .sup-hero-top{flex-direction:column;}
  .sup-hero-actions{width:100%;}
}
