/* American Samoa Luxe Site — static, premium, framework-free */
:root{
  --bg0:#060913;
  --bg1:#0b1022;
  --card: rgba(255,255,255,.06);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.70);
  --muted2: rgba(255,255,255,.55);
  --accent:#5eead4;
  --accent2:#60a5fa;
  --accent3:#a78bfa;
  --shadow: 0 18px 60px rgba(0,0,0,.45);
  --shadow2: 0 8px 30px rgba(0,0,0,.35);
  --radius: 22px;
  --radius2: 16px;
  --max: 1160px;
  --pad: clamp(18px, 2.2vw, 28px);
  --h1: clamp(34px, 4vw, 56px);
  --h2: clamp(22px, 2.6vw, 34px);
  --h3: clamp(18px, 2vw, 24px);
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; font-family: var(--sans); color: var(--text);
  background:
    radial-gradient(1200px 700px at 15% 10%, rgba(96,165,250,.20), transparent 60%),
    radial-gradient(900px 600px at 85% 20%, rgba(94,234,212,.18), transparent 65%),
    radial-gradient(900px 700px at 50% 110%, rgba(167,139,250,.20), transparent 60%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  min-height:100vh; overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.container{ width:min(var(--max), calc(100% - var(--pad)*2)); margin:0 auto; }

/* Header / nav */
header{
  position:sticky; top:0; z-index:50;
  background: rgba(7,10,20,.58);
  border-bottom:1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(12px);
}
.navbar{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; }
.brand{ display:flex; align-items:center; gap:12px; font-weight:700; letter-spacing:.2px; }
.brand svg{ width:28px; height:28px; }
.brand .sub{ display:block; font-weight:500; font-size:12px; color:var(--muted2); margin-top:2px; letter-spacing:.3px; }
nav ul{ list-style:none; display:flex; gap:18px; padding:0; margin:0; align-items:center; }
nav a{ font-size:14px; color:var(--muted); padding:10px 12px; border-radius:999px; transition:.18s ease; }
nav a:hover{ background: rgba(255,255,255,.08); color: var(--text); }
nav a.active{ color: var(--text); background: rgba(96,165,250,.12); border:1px solid rgba(96,165,250,.20); }

.cta{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:10px 14px; border-radius:999px;
  background: linear-gradient(135deg, rgba(94,234,212,.22), rgba(96,165,250,.20));
  border:1px solid rgba(255,255,255,.16);
  color: var(--text); font-weight:600;
  box-shadow: var(--shadow2);
}
.cta:hover{ transform: translateY(-1px); }
.cta svg{ width:18px; height:18px; opacity:.95; }

.theme-toggle{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: var(--muted);
}
.theme-toggle:hover{ color: var(--text); background: rgba(255,255,255,.08); }
.theme-toggle svg{ width:18px; height:18px; }

.mobile-toggle{
  display:none;
  width:44px; height:44px; border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: var(--text);
}
.mobile-drawer{ display:none; position:fixed; inset:0; z-index:60; background: rgba(0,0,0,.55); }
.drawer-panel{
  position:absolute; right:0; top:0; height:100%;
  width:min(360px, 90vw);
  background: rgba(10,14,28,.86);
  border-left:1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(14px);
  padding:18px;
}
.drawer-panel .top{ display:flex; align-items:center; justify-content:space-between; padding-bottom:14px; border-bottom:1px solid rgba(255,255,255,.10); }
.drawer-panel ul{ list-style:none; padding:14px 0 0; margin:0; display:flex; flex-direction:column; gap:10px; }
.drawer-panel a{ padding:12px 12px; border-radius:14px; background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.10); color: var(--text); }
.drawer-panel a:hover{ background: rgba(255,255,255,.08); }

/* Buttons / badges */
.badge{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:999px;
  background: rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow2);
  font-size:13px; color: var(--muted);
}
.badge .dot{ width:8px; height:8px; border-radius:50%; background: linear-gradient(135deg,var(--accent),var(--accent2)); box-shadow: 0 0 0 6px rgba(94,234,212,.08); }
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 16px; border-radius: 999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  font-weight:600;
  box-shadow: var(--shadow2);
  transition:.18s ease;
}
.btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,.08); }
.btn.primary{
  background: linear-gradient(135deg, rgba(94,234,212,.22), rgba(96,165,250,.18));
  border:1px solid rgba(255,255,255,.18);
}
.btn svg{ width:18px; height:18px; }
.mini-btn{
  display:inline-flex; align-items:center; gap:8px;
  padding: 9px 12px; border-radius: 999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text); font-weight:600; font-size: 13px;
}
.mini-btn:hover{ background: rgba(255,255,255,.08); }
.mini-btn svg{ width:16px; height:16px; }

/* Hero */
.hero{ padding: 34px 0 18px; position:relative; }
.hero-grid{ display:grid; grid-template-columns: 1.2fr .8fr; gap: 26px; align-items:stretch; }
.hero-left{
  padding: 28px; border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(900px 500px at 15% 0%, rgba(94,234,212,.18), transparent 55%),
    radial-gradient(700px 500px at 90% 15%, rgba(96,165,250,.18), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
  overflow:hidden; position:relative;
}
h1{ font-size: var(--h1); line-height:1.02; margin: 14px 0 14px; letter-spacing:-.6px; }
.lead{ font-size:18px; color:var(--muted); line-height:1.6; max-width: 58ch; }
.hero-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:18px; }
.kpis{ display:grid; grid-template-columns: repeat(3, 1fr); gap:12px; margin-top: 20px; }
.kpi{ border-radius: 18px; border:1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.05); padding: 14px; }
.kpi .num{ font-size:18px; font-weight:800; }
.kpi .lab{ font-size:12px; color:var(--muted2); margin-top:6px; line-height:1.25; }
.hero-right{ border-radius: var(--radius); border:1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.04); box-shadow: var(--shadow); overflow:hidden; }
.hero-media{
  height: 100%; min-height: 420px;
  background: linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.45)), url("../assets/hero.jpg");
  background-size: cover; background-position:center;
  position:relative;
}
.hero-media.fallback{
  background:
    radial-gradient(900px 700px at 50% 10%, rgba(96,165,250,.20), transparent 58%),
    radial-gradient(800px 600px at 20% 70%, rgba(94,234,212,.18), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.hero-overlay{ position:absolute; inset:0; padding: 18px; display:flex; flex-direction:column; justify-content:flex-end; gap:12px; }
.hero-card{ border-radius: 18px; border:1px solid rgba(255,255,255,.14); background: rgba(10,14,28,.58); backdrop-filter: blur(12px); padding: 14px; }
.hero-card .title{ font-weight:800; }
.hero-card .meta{ font-size:13px; color:var(--muted); line-height:1.5; margin-top:6px; }

/* Sections */
.section{ padding: 36px 0; }
.section h2{ font-size: var(--h2); margin: 0 0 12px; letter-spacing:-.3px; }
.section p.desc{ color: var(--muted); margin: 0 0 18px; max-width: 70ch; line-height:1.65; }
.grid3{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.grid2{ display:grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.card{
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  padding: 16px;
  box-shadow: var(--shadow2);
  overflow:hidden; position:relative;
}
.card .icon{
  width:42px; height:42px; border-radius:14px;
  display:grid; place-items:center;
  background: rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
}
.card h3{ margin: 12px 0 8px; font-size: var(--h3); letter-spacing:-.2px; }
.card p{ margin:0; color:var(--muted); line-height:1.65; font-size:15px; }
.link{ display:inline-flex; align-items:center; gap:8px; margin-top: 12px; font-size: 14px; color: rgba(94,234,212,.92); }
.link svg{ width:16px; height:16px; }
.split{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; align-items:stretch; }
.panel{ border-radius: var(--radius); border:1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.05); padding: 18px; box-shadow: var(--shadow2); }
.list{ margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:10px; }
.list li{ display:flex; gap:12px; align-items:flex-start; padding: 12px; border-radius: 16px; border:1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.04); }
.check{ width:22px; height:22px; border-radius: 8px; display:grid; place-items:center; background: rgba(94,234,212,.12); border:1px solid rgba(94,234,212,.22); margin-top: 1px; }
.small{ font-size:13px; color: var(--muted2); line-height:1.55; }
hr.sep{ border:0; height:1px; background: rgba(255,255,255,.10); margin: 22px 0; }

/* Gallery */
.gallery{ display:grid; grid-template-columns: repeat(12, 1fr); gap: 12px; }
.tile{
  border-radius: 18px; border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  overflow:hidden; position:relative; cursor:pointer;
  min-height: 170px; box-shadow: var(--shadow2);
}
.tile .img{ position:absolute; inset:0; background-size:cover; background-position:center; }
.tile .cap{
  position:absolute; left:12px; right:12px; bottom:12px;
  border-radius: 14px; background: rgba(10,14,28,.55);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  padding: 10px;
}
.tile .cap .t{ font-weight:800; font-size:14px; }
.tile .cap .s{ color:var(--muted); font-size:12px; margin-top:4px; line-height:1.35; }
.t1{ grid-column: span 5; } .t2{ grid-column: span 4; } .t3{ grid-column: span 3; } .t4{ grid-column: span 6; } .t5{ grid-column: span 6; }

/* Pages */
.breadcrumb{ display:flex; align-items:center; gap:10px; color: var(--muted2); font-size: 13px; }
.breadcrumb a{ color: var(--muted); } .breadcrumb a:hover{ color: var(--text); }
.page-head{ padding: 28px 0 10px; }
.page-head h1{ font-size: clamp(30px, 3.6vw, 46px); margin: 10px 0; }
.page-head p{ margin:0; color: var(--muted); line-height:1.65; max-width: 78ch; }

.table{
  width:100%; border-collapse:separate; border-spacing:0; overflow:hidden;
  border-radius: 18px; border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.table th, .table td{ padding: 14px; border-bottom: 1px solid rgba(255,255,255,.08); text-align:left; font-size: 14px; }
.table th{ color: rgba(255,255,255,.84); background: rgba(255,255,255,.05); }
.table td{ color: var(--muted); }
.table tr:last-child td{ border-bottom: 0; }

/* Modal */
.modal{ position:fixed; inset:0; z-index:90; display:none; background: rgba(0,0,0,.62); padding: 18px; }
.modal .box{
  width: min(980px, 100%); margin: 4vh auto 0;
  border-radius: 22px; border:1px solid rgba(255,255,255,.14);
  background: rgba(10,14,28,.88); backdrop-filter: blur(14px);
  box-shadow: var(--shadow); overflow:hidden;
}
.modal .top{ display:flex; align-items:center; justify-content:space-between; padding: 14px; border-bottom: 1px solid rgba(255,255,255,.10); }
.modal .top .t{ font-weight:800; }
.modal .content{ padding: 14px; }
.modal .img{ width:100%; height: min(55vh, 520px); border-radius: 18px; border:1px solid rgba(255,255,255,.10); background-size: cover; background-position:center; }
.modal .desc{ color: var(--muted); line-height:1.6; margin-top: 10px; }

/* v2 directory + filters */
.chips{ display:flex; flex-wrap:wrap; gap:10px; margin: 14px 0 0; }
.chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 12px; border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: var(--muted);
  font-size: 13px;
  cursor:pointer; user-select:none;
}
.chip.active{ color: var(--text); border-color: rgba(94,234,212,.26); background: rgba(94,234,212,.10); }
.chip .mini{ width:8px; height:8px; border-radius:50%; background: linear-gradient(135deg,var(--accent),var(--accent2)); opacity:.9; }

.searchbar{
  display:flex; gap:10px; align-items:center;
  padding: 12px; border-radius: 18px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
}
.searchbar input{ flex:1; border:0; outline:0; background: transparent; color: var(--text); font-size: 14px; }
.searchbar .kbd{
  font-family: var(--mono); font-size: 12px;
  color: rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  padding: 6px 8px; border-radius: 10px;
}
.dir{ display:grid; grid-template-columns: repeat(12, 1fr); gap: 14px; }
.dircard{
  grid-column: span 4;
  border-radius: 20px; border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  box-shadow: var(--shadow2);
  overflow:hidden; position:relative; min-height: 260px;
  transition: .18s ease;
}
.dircard:hover{ transform: translateY(-2px); }
.dircard .media{ height: 140px; background-size: cover; background-position:center; background-image: url("../assets/placeholder-hero.svg"); }
.dircard .body{ padding: 14px; }
.dircard .tagrow{ display:flex; gap:8px; flex-wrap:wrap; }
.pill{
  font-size: 12px; color: rgba(255,255,255,.70);
  padding: 6px 10px; border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
}
.dircard h3{ margin:10px 0 6px; font-size: 18px; letter-spacing:-.2px;}
.dircard p{ margin:0; color: var(--muted); line-height:1.55; font-size: 14px;}
.dircard .row{ display:flex; align-items:center; justify-content:space-between; margin-top: 12px; }
.stat{ font-size: 12px; color: rgba(255,255,255,.55); }

.timeline{ display:flex; flex-direction:column; gap: 10px; }
.step{ display:grid; grid-template-columns: 24px 1fr; gap: 12px; padding: 12px; border-radius: 18px; border:1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.04); }
.step .mark{ width:24px; height:24px; border-radius: 10px; background: rgba(96,165,250,.12); border:1px solid rgba(96,165,250,.22); display:grid; place-items:center; font-size: 12px; font-weight: 800; }
.step .t{ font-weight: 800; }
.step .s{ color: var(--muted); margin-top:4px; line-height:1.55; font-size: 14px; }

/* Footer */
footer{ padding: 26px 0 40px; border-top:1px solid rgba(255,255,255,.10); color: var(--muted2); }
.footgrid{ display:grid; gap: 14px; grid-template-columns: 1.3fr .7fr .7fr; }
footer a{ color: var(--muted); } footer a:hover{ color: var(--text); }
.footnote{ margin-top: 16px; font-size: 12px; color: rgba(255,255,255,.45); }

/* Responsive */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .hero-media{ min-height: 340px; }
  .kpis{ grid-template-columns: 1fr; }
  .grid3{ grid-template-columns: 1fr; }
  .grid2{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .footgrid{ grid-template-columns: 1fr; }
  nav ul{ display:none; }
  .mobile-toggle{ display:inline-grid; place-items:center; }
  .dircard{ grid-column: span 12; }
}
