/* ============================================================
   CHARTER SOUTH AFRICA — Coastal Luxury Design System
   Ported from design/styles/csa.css and extended for the live app.
   Cream/sand canvas · deep ocean navy · muted teal · brass
   Serif display (Cormorant Garamond) · grotesque UI (Hanken Grotesk)
   ============================================================ */

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

:root{
  --sand-50:#fbf9f4; --sand-100:#f6f2e9; --sand-150:#efe9db; --sand-200:#e7decb; --sand-300:#d9ccb2; --paper:#fffdf8;
  --navy-900:#0d1f2d; --navy-800:#13293a; --navy-700:#1c3a4f; --navy-600:#2b5066; --navy-500:#3e6a83; --navy-400:#6f93a6;
  --teal-700:#1f5a52; --teal-600:#2a7166; --teal-500:#3c8a7d; --teal-100:#dcebe6; --teal-50:#e9f2ef;
  --brass-600:#9a7634; --brass-500:#b8923f; --brass-400:#c7a456; --brass-100:#ecdfc4;
  --ok:#2e7d6b; --warn:#b87333; --danger:#a8443a; --info:#3e6a83;
  --ink:#16242d; --ink-soft:#46586280; --ink-60:#3a4a55; --ink-40:#6f8089;
  --hairline:#0d1f2d14; --hairline-2:#0d1f2d0d;
  --serif:'Cormorant Garamond','Times New Roman',serif;
  --sans:'Hanken Grotesk',-apple-system,system-ui,sans-serif;
  --r-xs:6px; --r-sm:10px; --r-md:14px; --r-lg:20px; --r-xl:28px;
  --sh-sm:0 1px 2px rgba(13,31,45,.06),0 1px 1px rgba(13,31,45,.04);
  --sh-md:0 4px 14px rgba(13,31,45,.08),0 1px 3px rgba(13,31,45,.05);
  --sh-lg:0 18px 48px rgba(13,31,45,.14),0 4px 12px rgba(13,31,45,.06);
  --sh-xl:0 32px 80px rgba(13,31,45,.22);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans); color:var(--ink); background:var(--sand-100);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; line-height:1.5; letter-spacing:.001em;
}
a{color:inherit;text-decoration:none}

/* ---------- Accessibility: visible keyboard focus + skip link ---------- */
a:focus-visible,button:focus-visible,.btn:focus-visible,.chip:focus-visible,.navlink:focus-visible,
.nav-link:focus-visible,.mobile-tab:focus-visible,[tabindex]:focus-visible,.field:focus-visible{
  outline:3px solid var(--brass-500);outline-offset:2px;border-radius:var(--r-xs)
}
.skip-link{position:absolute;left:-9999px;top:8px;z-index:1000;background:var(--navy-900);color:#fff;padding:10px 16px;border-radius:8px;font-weight:600;font-size:14px}
.skip-link:focus{left:8px}

/* ---------- Type ---------- */
.serif{font-family:var(--serif)}
.display{font-family:var(--serif);font-weight:500;line-height:1.02;letter-spacing:-.01em}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-600)}
.eyebrow.teal{color:var(--teal-600)} .eyebrow.muted{color:var(--ink-40)}
.kicker{font-size:13px;letter-spacing:.02em;color:var(--ink-40)}
.mono{font-family:'SFMono-Regular',ui-monospace,'JetBrains Mono',Menlo,monospace}
h1,h2,h3,h4{margin:0}
.t-hero{font-family:var(--serif);font-weight:500;font-size:64px;line-height:.98;letter-spacing:-.015em}
.t-h1{font-family:var(--serif);font-weight:500;font-size:44px;line-height:1.02;letter-spacing:-.01em}
.t-h2{font-family:var(--serif);font-weight:500;font-size:32px;line-height:1.05}
.t-h3{font-family:var(--serif);font-weight:600;font-size:23px;line-height:1.1}
.t-title{font-weight:600;font-size:17px;letter-spacing:-.01em}
.t-body{font-size:15px;color:var(--ink-60);line-height:1.55}
.t-sm{font-size:13px;color:var(--ink-40)} .t-xs{font-size:11.5px;color:var(--ink-40)}
.price{font-family:var(--serif);font-weight:600;letter-spacing:-.01em}

/* ---------- Buttons ---------- */
.btn{font-family:var(--sans);font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:8px;justify-content:center;padding:11px 20px;border-radius:999px;border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:.18s ease;text-decoration:none}
.btn-primary{background:var(--navy-800);color:#fbf9f4} .btn-primary:hover{background:var(--navy-900)}
.btn-brass{background:var(--brass-500);color:#1c1405} .btn-brass:hover{background:var(--brass-400)}
.btn-teal{background:var(--teal-600);color:#eef6f3} .btn-teal:hover{background:var(--teal-500)}
.btn-ghost{background:transparent;color:var(--navy-800);border-color:#0d1f2d33} .btn-ghost:hover{background:#0d1f2d08;border-color:#0d1f2d55}
.btn-soft{background:var(--paper);color:var(--navy-800);border-color:var(--hairline);box-shadow:var(--sh-sm)} .btn-soft:hover{background:#fff}
.btn-lg{padding:14px 26px;font-size:15px} .btn-sm{padding:8px 14px;font-size:12.5px}
.btn-icon{width:38px;height:38px;padding:0;border-radius:999px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---------- Chips / badges / pills ---------- */
.chip{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border-radius:999px;font-size:12.5px;font-weight:500;background:var(--paper);color:var(--ink-60);border:1px solid var(--hairline);cursor:pointer;transition:.15s;white-space:nowrap}
.chip:hover{border-color:#6f93a680;color:var(--navy-800)}
.chip.active{background:var(--navy-800);color:var(--sand-50);border-color:var(--navy-800)}
.tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.02em}
.tag-brass{background:var(--brass-100);color:var(--brass-600)} .tag-teal{background:var(--teal-50);color:var(--teal-700)}
.tag-navy{background:#13293a14;color:var(--navy-800)} .tag-ok{background:#2e7d6b1a;color:#1f6657}
.tag-warn{background:#b873331a;color:#8c5418} .tag-danger{background:#a8443a1a;color:#8a352c}
.dot{width:7px;height:7px;border-radius:99px;display:inline-block}

/* ---------- Cards ---------- */
.card{background:var(--paper);border:1px solid var(--hairline);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}
.card-flat{background:var(--paper);border:1px solid var(--hairline);border-radius:var(--r-md)}
.panel{background:var(--paper);border:1px solid var(--hairline);border-radius:var(--r-md)}
.hairline{height:1px;background:var(--hairline);border:0}

/* ---------- Image placeholders (editorial photography stand-ins) ---------- */
.ph{position:relative;overflow:hidden;background:repeating-linear-gradient(135deg,#0d1f2d0a 0 2px,transparent 2px 11px),linear-gradient(160deg,var(--navy-700),var(--navy-900));color:#ffffffcc}
.ph.teal{background:repeating-linear-gradient(135deg,#ffffff12 0 2px,transparent 2px 11px),linear-gradient(160deg,var(--teal-600),var(--teal-700))}
.ph.sand{background:repeating-linear-gradient(135deg,#0d1f2d0a 0 2px,transparent 2px 11px),linear-gradient(160deg,var(--sand-200),var(--sand-300));color:#5b4a2e}
.ph.brass{background:repeating-linear-gradient(135deg,#ffffff14 0 2px,transparent 2px 11px),linear-gradient(160deg,var(--brass-400),var(--brass-600));color:#241803}
.ph-label{position:absolute;left:12px;bottom:11px;font-family:ui-monospace,monospace;font-size:10.5px;letter-spacing:.04em;padding:4px 8px;border-radius:6px;background:#0d1f2d55;color:#fff;backdrop-filter:blur(3px);text-transform:lowercase}
.ph.sand .ph-label,.ph.brass .ph-label{background:#ffffff66;color:#3a2c12}

/* ---------- Inputs ---------- */
.field{width:100%;font-family:var(--sans);font-size:14px;color:var(--ink);padding:12px 14px;border-radius:var(--r-sm);border:1px solid var(--hairline);background:var(--paper);outline:none;transition:.15s}
.field:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px #2b506622}
.label{font-size:12px;font-weight:600;color:var(--ink-60);letter-spacing:.01em;margin-bottom:6px;display:block}
select.field{appearance:none;cursor:pointer}

/* ---------- Avatars / misc ---------- */
.avatar{border-radius:999px;background:var(--navy-700);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-family:var(--serif)}
.scrim{background:linear-gradient(to top,#0d1f2dcc 0%,#0d1f2d33 45%,transparent 75%)}
.divider-v{width:1px;background:var(--hairline);align-self:stretch}

/* ---------- Dashboard chrome ---------- */
.kpi{font-family:var(--serif);font-weight:600;font-size:30px;letter-spacing:-.01em;color:var(--navy-900);line-height:1}
.navlink{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;color:#cdd9e0;cursor:pointer;transition:.14s;text-decoration:none}
.navlink:hover{background:#ffffff10;color:#fff} .navlink.active{background:#ffffff16;color:#fff} .navlink .ic{opacity:.8}

/* ---------- Tables ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-40);padding:10px 14px;border-bottom:1px solid var(--hairline)}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--hairline-2);color:var(--ink-60)}
.tbl tr:last-child td{border-bottom:0} .tbl tbody tr:hover td{background:#0d1f2d04}

/* ---------- Utility ---------- */
.flex{display:flex} .col{display:flex;flex-direction:column}
.between{justify-content:space-between} .center{align-items:center} .jc{justify-content:center}
.wrap{flex-wrap:wrap}
.gap-2{gap:2px}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-14{gap:14px}.gap-16{gap:16px}.gap-18{gap:18px}.gap-20{gap:20px}.gap-24{gap:24px}.gap-28{gap:28px}.gap-32{gap:32px}.gap-40{gap:40px}
.grow{flex:1} .mta{margin-left:auto}
.rounded{border-radius:var(--r-md)} .rounded-lg{border-radius:var(--r-lg)} .ov-hidden{overflow:hidden}
.clickable{cursor:pointer}
.grid{display:grid}
.g-2{grid-template-columns:repeat(2,1fr)} .g-3{grid-template-columns:repeat(3,1fr)} .g-4{grid-template-columns:repeat(4,1fr)}

/* ---------- App layout: consumer ---------- */
.consumer-shell{min-height:100vh;background:var(--paper);display:flex;flex-direction:column}
.consumer-nav{display:flex;justify-content:space-between;align-items:center;padding:18px 40px;position:relative;z-index:3}
.consumer-nav.solid{border-bottom:1px solid var(--hairline);background:var(--paper)}
.nav-center{display:flex;gap:28px;align-items:center;position:absolute;left:50%;transform:translateX(-50%)}
.nav-link{font-size:14px;font-weight:500;color:var(--ink-60);cursor:pointer;padding-bottom:2px;border-bottom:2px solid transparent}
.nav-link.active{font-weight:600;color:var(--navy-900);border-bottom-color:var(--brass-500)}
.nav-link.dark{color:#ffffffcc} .nav-link.dark.active{color:#fff;border-bottom-color:var(--brass-400)}
.section{padding:46px 40px}
.maxw{max-width:1240px;margin:0 auto;width:100%}
.footer{display:flex;justify-content:space-between;align-items:center;padding:28px 40px;border-top:1px solid var(--hairline);background:var(--sand-100);flex-wrap:wrap;gap:16px}
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:10px;height:380px;border-radius:18px;overflow:hidden}
.gallery > .ph{border-radius:0}
.detail-wrap{display:flex;gap:40px}
.mod-gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:10px;height:300px}
@media (max-width:900px){.mod-gallery{grid-template-columns:1fr 1fr;height:240px}.moderation{flex-direction:column}.moderation > div:first-child{width:100%!important;border-right:0!important;border-bottom:1px solid var(--hairline)}}
@media (max-width:900px){
  .gallery{grid-template-columns:1fr 1fr;height:300px}
  .gallery > .ph:first-child{grid-row:span 1!important;grid-column:span 2}
  .detail-wrap{flex-direction:column}
  .detail-wrap > div[style*="340px"]{flex:1 1 auto!important}
}

/* ---------- App layout: dashboard ---------- */
.dash{display:flex;min-height:100vh;background:var(--sand-100)}
.dash-side{width:236px;background:var(--navy-900);flex-shrink:0;padding:20px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.dash-main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 28px;border-bottom:1px solid var(--hairline);background:var(--paper);flex-shrink:0}
.dash-body{padding:24px;overflow:auto}
.search-pill{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--sand-100);border-radius:99px;border:1px solid var(--hairline);min-width:200px;color:var(--ink-40);font-size:13px}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .consumer-nav{padding:14px 20px} .nav-center{display:none}
  .section{padding:30px 20px} .footer{padding:20px}
  .t-hero,.display[style*="76px"]{font-size:44px!important}
  .g-3,.g-4{grid-template-columns:1fr 1fr}
  .dash-side{display:none}
}
@media (max-width:620px){
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .pass-body{flex-direction:column}
  .pass-body > div[style*="220px"]{flex:1 1 auto!important}
}

/* ---------- Mobile bottom tab bar (native-app nav) ---------- */
.mobile-tabbar{display:none}
@media (max-width:760px){
  .mobile-tabbar{
    display:flex;justify-content:space-between;align-items:center;
    position:fixed;left:0;right:0;bottom:0;z-index:50;
    padding:10px 24px calc(10px + env(safe-area-inset-bottom));
    background:linear-gradient(to top,var(--paper) 78%,#fffdf800);
    border-top:1px solid var(--hairline);backdrop-filter:blur(8px);
  }
  .mobile-tab{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;color:var(--ink-40)}
  .mobile-tab span{font-size:10.5px;font-weight:500}
  .mobile-tab.active{color:var(--navy-900)}
  .mobile-tab.active span{font-weight:600}
  /* Keep the footer/content clear of the fixed bar */
  .consumer-shell,.section.maxw:last-of-type{padding-bottom:84px}
  .footer{margin-bottom:72px}
}
