/* =========================
   AMBER — Pretty Stylesheet
   (matches your HTML classes)
========================= */

/* ---------- Tokens ---------- */
:root{
  --bg1:#f6fbff;
  --bg2:#fff7fb;
  --bg3:#f7fff9;

  --ink:#151c2a;
  --muted: rgba(21,28,42,.72);
  --muted2: rgba(21,28,42,.56);

  --card: rgba(255,255,255,.72);
  --card-strong: rgba(255,255,255,.90);
  --border: rgba(21,28,42,.12);

  --sky:#78b7ff;
  --mint:#63e6be;
  --lav:#bda6ff;
  --peach:#ffd3a6;
  --rose:#ffb3c7;
  --sun:#ffe08a;

  --shadow: 0 18px 50px rgba(20,30,60,.12);
  --shadow-soft: 0 12px 28px rgba(20,30,60,.08);

  --r-2xl: 26px;
  --r-xl: 22px;
  --r-lg: 18px;
  --r-md: 14px;

  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* ---------- Base ---------- */
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: var(--font);
  color: var(--ink);
  background:
    radial-gradient(900px 520px at 12% 8%, rgba(120,183,255,.26), transparent 60%),
    radial-gradient(900px 520px at 88% 12%, rgba(189,166,255,.22), transparent 62%),
    radial-gradient(900px 520px at 50% 96%, rgba(99,230,190,.18), transparent 66%),
    linear-gradient(180deg, var(--bg1), var(--bg2) 46%, var(--bg3));
}

a{ color: inherit; }
img{ max-width:100%; }
code{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: .95em;
  padding: 2px 6px;
  border-radius: 10px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.85);
}

/* =========================
   SPA PAGE SWITCHING
========================= */
body > main{ display:none; }
body > main.is-active{ display:block; }

/* ---------- Page container ---------- */
.amber-home,
.amber-space,
.amber-map,
.amber-goals,
.amber-refresh,
.amber-contact{
  max-width: 1120px;
  margin: 0 auto;
  padding: 22px 18px 26px;
}

/* ---------- Topbar ---------- */
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 14px 16px;
  border-radius: var(--r-2xl);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.62);
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow-soft);
  position: sticky;
  top: 14px;
  z-index: 20;
}

.brand{ display:flex; align-items:center; gap:12px; min-width: 240px; }
.logo{
  width: 44px; height:44px;
  border-radius: 16px;
  display:grid; place-items:center;
  font-weight: 950;
  letter-spacing: .5px;
  color:#0e1422;
  background:
    radial-gradient(18px 18px at 30% 28%, rgba(255,255,255,.96), transparent 62%),
    linear-gradient(135deg, rgba(120,183,255,.90), rgba(189,166,255,.72));
  border: 1px solid rgba(21,28,42,.10);
  box-shadow: 0 16px 28px rgba(120,183,255,.18);
}
.brand-text{ display:grid; gap:2px; }
.brand-name{ margin:0; font-size: 18px; }
.brand-tagline{ margin:0; font-size: 12.5px; color: var(--muted); }

.nav{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  justify-content:flex-end;
}
.nav-link{
  text-decoration:none;
  color: rgba(21,28,42,.78);
  font-size: 13px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.55);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}
.nav-link:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.85);
  box-shadow: 0 12px 20px rgba(20,30,60,.10);
}
.nav-link[aria-current="page"]{
  background: linear-gradient(135deg, rgba(120,183,255,.18), rgba(189,166,255,.14));
  border-color: rgba(120,183,255,.35);
}

/* ---------- Buttons ---------- */
.btn{
  border: 1px solid rgba(21,28,42,.12);
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 850;
  cursor:pointer;
  color: var(--ink);
  background: rgba(255,255,255,.86);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  box-shadow: 0 12px 20px rgba(20,30,60,.08);
  display:inline-flex;
  align-items:center;
  gap: 8px;
}
.btn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.96);
  box-shadow: 0 16px 28px rgba(20,30,60,.12);
}
.btn:active{ transform: translateY(0); }

.btn-primary{
  border-color: rgba(120,183,255,.45);
  background: linear-gradient(135deg, rgba(120,183,255,.34), rgba(189,166,255,.18));
}
.btn-secondary{
  border-color: rgba(99,230,190,.45);
  background: linear-gradient(135deg, rgba(99,230,190,.28), rgba(120,183,255,.16));
}
.btn-ghost{
  background: rgba(255,255,255,.45);
  box-shadow: none;
}
.btn[disabled]{ opacity:.55; cursor:not-allowed; transform:none; box-shadow:none; }

.btn-small{ padding: 8px 12px; font-size: 13px; }
.ico{ line-height: 1; }

/* ---------- Shared surfaces ---------- */
.panel, .card, .snapshot, .callout, .mode-card, .feed-card, .goal-card, .topic-item, .quiz-card, .break-box, .info-item{
  border-radius: var(--r-2xl);
  border: 1px solid var(--border);
  background: var(--card);
  box-shadow: var(--shadow-soft);
}

/* ---------- Footer ---------- */
.footer{
  margin-top: 16px;
  padding: 12px 14px;
  border-radius: var(--r-2xl);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.65);
  color: var(--muted2);
  font-size: 12.5px;
  text-align:center;
  box-shadow: 0 10px 16px rgba(20,30,60,.05);
}

/* =========================
   HOME — HERO
========================= */
.hero{
  margin-top: 18px;
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 14px;
  align-items: stretch;
}

.hero-left{
  padding: 22px;
  border-radius: var(--r-2xl);
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.74);
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.hero-left::before{
  content:"";
  position:absolute;
  inset:-80px -40px auto auto;
  width: 260px;
  height: 260px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.70), transparent 55%),
              radial-gradient(circle at 60% 70%, rgba(120,183,255,.34), transparent 60%),
              radial-gradient(circle at 30% 80%, rgba(189,166,255,.26), transparent 60%);
  filter: blur(2px);
  opacity:.9;
  pointer-events:none;
}
.hero-title{
  margin: 0 0 10px;
  font-size: 40px;
  letter-spacing: -0.9px;
  line-height: 1.06;
}
.hero-subtitle{
  margin: 0 0 16px;
  color: var(--muted);
  line-height: 1.65;
  font-size: 15.5px;
  max-width: 70ch;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-bottom: 14px;
}

.hero-note{
  margin-top: 8px;
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding: 14px 14px;
  border-radius: 18px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.78);
  box-shadow: 0 12px 18px rgba(20,30,60,.06);
  color: rgba(21,28,42,.82);
}
.note-ico{
  width: 34px; height:34px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(255,224,138,.55), rgba(255,179,199,.25));
  border: 1px solid rgba(21,28,42,.10);
}

.hero-right .snapshot{
  padding: 18px;
  height: 100%;
  background: rgba(255,255,255,.62);
  position:relative;
  overflow:hidden;
}
.snapshot::before{
  content:"";
  position:absolute;
  inset:auto -80px -90px auto;
  width: 240px;
  height: 240px;
  background: radial-gradient(circle at 30% 30%, rgba(99,230,190,.32), transparent 62%),
              radial-gradient(circle at 70% 60%, rgba(120,183,255,.26), transparent 62%);
  filter: blur(2px);
  opacity:.9;
  pointer-events:none;
}
.snapshot-title{
  margin: 0 0 12px;
  font-weight: 950;
  letter-spacing: .2px;
}
.snapshot-grid{
  margin:0;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.snapshot-item{
  padding: 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.80);
  border: 1px solid rgba(21,28,42,.10);
  box-shadow: 0 10px 16px rgba(20,30,60,.06);
}
.snapshot-label{
  font-size: 12px;
  color: var(--muted2);
  margin:0 0 6px;
}
.snapshot-value{
  margin:0;
  font-weight: 950;
  font-size: 16px;
}
.snapshot-hint{
  margin: 12px 0 0;
  color: var(--muted2);
  font-size: 12.5px;
}

/* =========================
   HOME — CARDS
========================= */
.cards{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.card{
  padding: 18px;
  background: rgba(255,255,255,.70);
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute;
  inset:-80px -80px auto auto;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.70), transparent 55%),
              radial-gradient(circle at 70% 70%, rgba(255,179,199,.20), transparent 60%);
  opacity:.65;
  pointer-events:none;
}
.card-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.card-kicker{
  margin:0 0 6px;
  color: var(--muted2);
  font-size: 12.5px;
}
.card-title{
  margin:0;
  font-size: 28px;
  letter-spacing: -0.6px;
}
.card-icon{
  width: 44px; height:44px;
  border-radius: 16px;
  display:grid; place-items:center;
  background: rgba(255,255,255,.76);
  border: 1px solid rgba(21,28,42,.10);
  box-shadow: 0 12px 18px rgba(20,30,60,.07);
  font-size: 20px;
}
.card-text{
  margin: 0 0 14px;
  color: var(--muted);
  line-height: 1.55;
  font-size: 14px;
}
.card-footer{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: auto;
}

/* Pet card special glow */
.pet-card::before{
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.72), transparent 58%),
              radial-gradient(circle at 70% 60%, rgba(99,230,190,.22), transparent 62%),
              radial-gradient(circle at 40% 90%, rgba(120,183,255,.20), transparent 62%);
  opacity:.85;
}

.pet-figure{
  margin: 10px 0 12px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.82);
  display:grid;
  place-items:center;
}
.pet-emoji{
  font-size: 40px;
  line-height: 1;
  filter: drop-shadow(0 10px 18px rgba(20,30,60,.10));
}

.progress{
  margin-top: 10px;
  padding: 12px 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(21,28,42,.10);
}
.progress-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom: 8px;
}
.progress-label{ color: var(--muted2); font-size: 12.5px; }
.progress-value{ font-weight: 950; }
.progress-bar{
  height: 10px;
  border-radius: 999px;
  background: rgba(21,28,42,.08);
  overflow:hidden;
  border: 1px solid rgba(21,28,42,.10);
}
.progress-fill{
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, rgba(120,183,255,.90), rgba(99,230,190,.85));
}
.progress-hint{
  margin: 10px 0 0;
  font-size: 12.5px;
  color: var(--muted2);
}

/* Pills */
.pill-row{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
}
.pill{
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.80);
  border: 1px solid rgba(21,28,42,.10);
  font-size: 12.5px;
  color: rgba(21,28,42,.78);
}

/* =========================
   HOME — MOTIVATION
========================= */
.motivation{
  margin-top: 16px;
  padding: 18px;
  border-radius: var(--r-2xl);
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.62);
  box-shadow: var(--shadow-soft);
}
.motivation > h2{
  margin: 0 0 12px;
  font-size: 26px;
  letter-spacing: -0.5px;
}
.motivation-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.panel{
  padding: 16px;
}
.panel-title{ margin:0 0 8px; font-size: 16px; }
.panel-text{ margin: 0 0 10px; color: var(--muted); line-height: 1.55; }
.panel-list{
  margin: 0;
  padding-left: 18px;
  color: rgba(21,28,42,.80);
  line-height: 1.7;
}

/* =========================
   SHARED — PAGE HEAD / PANEL
========================= */
.page-head{
  margin-top: 18px;
  display:grid;
  grid-template-columns: 1.35fr .95fr;
  gap: 14px;
  align-items: stretch;
}
.page-head-left{
  padding: 18px;
  border-radius: var(--r-2xl);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.74);
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.page-head-left::before{
  content:"";
  position:absolute;
  inset:auto -70px -90px auto;
  width: 260px;
  height: 260px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.70), transparent 55%),
              radial-gradient(circle at 70% 60%, rgba(255,224,138,.22), transparent 62%),
              radial-gradient(circle at 30% 80%, rgba(120,183,255,.18), transparent 62%);
  opacity:.8;
  pointer-events:none;
}
.page-title{
  margin:0 0 8px;
  font-size: 34px;
  letter-spacing: -0.7px;
}
.page-subtitle{
  margin:0;
  color: var(--muted);
  line-height: 1.65;
  font-size: 15px;
  max-width: 70ch;
}
.page-head-right{
  padding: 18px;
  border-radius: var(--r-2xl);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.62);
  box-shadow: var(--shadow-soft);
}
.statline{
  display:flex;
  justify-content:space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 18px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.82);
  box-shadow: 0 10px 16px rgba(20,30,60,.06);
  margin-bottom: 10px;
}
.statlabel{ color: var(--muted2); font-size: 12.5px; }
.statvalue{ font-weight: 950; }
.tinyhint{ margin: 8px 0 0; font-size: 12.5px; color: var(--muted2); }

.panel-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 14px;
  margin-bottom: 12px;
}
.panel-hint{ margin:0; color: var(--muted); font-size: 13.5px; line-height: 1.45; }

/* =========================
   FORMS
========================= */
.form-grid{
  display:grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 12px;
}
.field{ display:grid; gap: 6px; }
.field-label{ font-size: 12.5px; color: var(--muted2); }

.field-input{
  width:100%;
  border-radius: 18px;
  border: 1px solid rgba(21,28,42,.12);
  background: rgba(255,255,255,.92);
  padding: 11px 12px;
  font-size: 14px;
  color: var(--ink);
  box-shadow: 0 10px 16px rgba(20,30,60,.05);
  outline:none;
  transition: border-color .15s ease, box-shadow .15s ease, transform .12s ease;
}
.field-input:focus{
  border-color: rgba(120,183,255,.55);
  box-shadow: 0 16px 24px rgba(120,183,255,.14);
  transform: translateY(-1px);
}
textarea.field-input{ resize: vertical; }

.form-actions{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: 12px;
}

/* =========================
   YOUR SPACE — TOOLBAR / TOPIC LIST / QUIZ
========================= */
.toolbar{
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  align-items:flex-end;
  justify-content:space-between;
  padding: 12px;
  border-radius: 22px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.70);
}
.field.small .field-input{ padding: 10px 12px; border-radius: 16px; }
.toolbar-actions{ display:flex; gap:10px; flex-wrap:wrap; }

.topic-list{ margin-top: 12px; display:grid; gap: 10px; }
.topic-item{
  padding: 14px;
  background: rgba(255,255,255,.70);
  display:flex;
  gap: 12px;
  align-items:flex-start;
  justify-content:space-between;
}
.topic-name{ margin:0 0 6px; font-size: 16px; letter-spacing: -0.2px; }
.topic-meta{ margin:0 0 10px; color: var(--muted2); font-size: 12.5px; }
.topic-tags{ display:flex; gap: 8px; flex-wrap:wrap; }
.tag{
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(21,28,42,.10);
  font-size: 12.5px;
}
.tag-good{ border-color: rgba(99,230,190,.45); background: rgba(99,230,190,.14); }
.tag-warn{ border-color: rgba(255,211,166,.55); background: rgba(255,211,166,.18); }
.topic-actions{ display:flex; gap: 8px; flex-wrap:wrap; }

.pager{
  margin-top: 12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}
.pager-info{ color: var(--muted2); font-size: 12.5px; }

/* Quiz */
.quiz-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.mini-title{
  margin: 0 0 10px;
  font-size: 14px;
  color: rgba(21,28,42,.85);
  letter-spacing: .2px;
}
.chip-row{ display:flex; flex-wrap:wrap; gap: 8px; }
.chip{
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.85);
  font-size: 12.5px;
}
.chip-muted{ opacity:.75; }
.chip-good{ border-color: rgba(99,230,190,.45); background: rgba(99,230,190,.14); }
.chip-mid{ border-color: rgba(120,183,255,.45); background: rgba(120,183,255,.14); }
.chip-warn{ border-color: rgba(255,211,166,.55); background: rgba(255,211,166,.18); }

.quiz-options{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.quiz-card{
  padding: 14px;
  background: rgba(255,255,255,.70);
}
.quiz-q{ margin:0 0 10px; color: rgba(21,28,42,.90); line-height: 1.5; }
.quiz-answers{ display:grid; gap: 8px; }
.answer{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  padding: 10px 10px;
  border-radius: 16px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.82);
}
.answer input{ margin-top: 2px; }

/* =========================
   FUTURE MAP — CALLOUTS / STEPS / MAP VIEW
========================= */
.big-picture{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.callout{
  padding: 14px;
  background: rgba(255,255,255,.70);
}
.callout-text{ margin: 0; color: var(--muted); line-height: 1.6; }

.milestone-grid{
  margin: 12px 0 0;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.milestone{
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.82);
}
.milestone-label{ color: var(--muted2); font-size: 12.5px; margin:0 0 6px; }
.milestone-value{ font-weight: 950; margin:0; }

.steps{
  margin: 0;
  padding: 0;
  list-style: none;
  display:grid;
  gap: 12px;
}
.step{
  padding: 14px;
  background: rgba(255,255,255,.70);
  display:grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items:start;
}
.step-title{ margin:0 0 8px; font-size: 18px; letter-spacing:-0.3px; }
.step-why{ margin:0 0 10px; color: var(--muted); line-height: 1.6; }
.step-meta{ display:flex; flex-wrap:wrap; gap: 8px; margin-bottom: 10px; }
.step-actions{ display:flex; flex-direction:column; gap: 10px; min-width: 180px; }

.step-locked{
  opacity:.88;
}
.step-locked .step-actions .btn-primary,
.step-locked .step-actions .btn-secondary{ opacity:.6; }

.details summary{
  cursor:pointer;
  font-weight: 850;
  color: rgba(21,28,42,.86);
  padding: 10px 10px;
  border-radius: 16px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.80);
}
.details-body{
  margin-top: 10px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.82);
}
.details-title{ margin: 0 0 8px; font-weight: 950; }
.checklist, .bullets{
  margin: 0;
  padding-left: 18px;
  color: rgba(21,28,42,.80);
  line-height: 1.65;
}

.map-view{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.map-col{
  padding: 14px;
  border-radius: 22px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.70);
}
.map-col-title{ margin:0 0 10px; color: var(--muted2); font-size: 12.5px; }
.node{
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.85);
  margin-bottom: 8px;
  font-weight: 800;
  font-size: 13px;
}
.node-done{ border-color: rgba(99,230,190,.45); background: rgba(99,230,190,.14); }
.node-mid{ border-color: rgba(120,183,255,.45); background: rgba(120,183,255,.14); }
.node-next{ border-color: rgba(189,166,255,.45); background: rgba(189,166,255,.14); }
.node-locked{ opacity:.70; }
.node-goal{ border-color: rgba(255,224,138,.55); background: rgba(255,224,138,.20); }

.legend{
  margin-top: 12px;
  display:flex;
  gap: 12px;
  flex-wrap:wrap;
  align-items:center;
  color: var(--muted2);
  font-size: 12.5px;
}
.legend-item{ display:flex; align-items:center; gap: 8px; }
.dot{
  width: 10px; height:10px;
  border-radius: 999px;
  border: 1px solid rgba(21,28,42,.12);
  background: rgba(255,255,255,.9);
}
.dot-done{ background: rgba(99,230,190,.80); }
.dot-mid{ background: rgba(120,183,255,.80); }
.dot-next{ background: rgba(189,166,255,.80); }
.dot-locked{ background: rgba(21,28,42,.20); }
.dot-goal{ background: rgba(255,224,138,.90); }

/* =========================
   GOALS — BOARD / REFLECTION
========================= */
.goals-board{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.goals-col{
  padding: 14px;
  border-radius: 22px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.70);
}
.col-title{
  margin:0 0 10px;
  font-size: 14px;
  color: rgba(21,28,42,.82);
}
.goal-card{
  padding: 12px;
  background: rgba(255,255,255,.80);
  border-radius: 20px;
  border: 1px solid rgba(21,28,42,.10);
  box-shadow: 0 10px 16px rgba(20,30,60,.06);
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.goal-text{ font-weight: 850; }
.goal-meta{ margin: 6px 0 0; color: var(--muted2); font-size: 12.5px; }
.goal-actions{ display:flex; gap: 8px; flex-wrap:wrap; }

.goal-check{ display:flex; gap: 10px; align-items:flex-start; }
.goal-check input{ margin-top: 2px; }

.reflection-grid{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
}

/* =========================
   REFRESH — MODES / FEED / BREAK
========================= */
.modes-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.mode-card{
  padding: 14px;
  background: rgba(255,255,255,.70);
}
.mode-title{ margin:0 0 8px; font-size: 16px; }
.mode-text{ margin:0 0 10px; color: var(--muted); line-height: 1.6; }

.feed-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.feed-card{
  padding: 14px;
  background: rgba(255,255,255,.70);
}
.feed-kicker{
  margin:0 0 6px;
  color: var(--muted2);
  font-size: 12.5px;
}
.feed-title{ margin:0 0 8px; font-size: 16px; letter-spacing:-0.2px; }
.feed-text{ margin:0 0 10px; color: var(--muted); line-height: 1.6; }
.feed-tag{
  display:inline-block;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.85);
  font-size: 12.5px;
  color: rgba(21,28,42,.78);
}
.feed-actions{
  margin-top: 12px;
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
}

.break-box{
  padding: 16px;
  background: rgba(255,255,255,.70);
}
.break-instruction{ margin:0 0 12px; color: var(--muted); line-height: 1.6; }
.break-timer{
  font-size: 56px;
  font-weight: 950;
  letter-spacing: -1px;
  text-align:center;
  padding: 14px 0;
  border-radius: 22px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.82);
  box-shadow: 0 12px 18px rgba(20,30,60,.06);
}
.break-hint{ margin: 10px 0 0; color: var(--muted2); font-size: 12.5px; }

.return-quote{
  margin: 0;
  padding: 14px 16px;
  border-radius: 22px;
  border: 1px solid rgba(21,28,42,.10);
  background: rgba(255,255,255,.82);
  color: rgba(21,28,42,.86);
  font-weight: 850;
}
.return-actions{ margin-top: 12px; display:flex; gap: 10px; flex-wrap:wrap; }

/* =========================
   CONTACT — GRID / INFO / FAQ
========================= */
.contact-grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 12px;
}
.link{ color: rgba(21,28,42,.86); text-decoration: underline; text-underline-offset: 3px; }

.info-block{ display:grid; gap: 10px; }
.info-item{
  padding: 12px;
  background: rgba(255,255,255,.72);
}
.info-text{ margin: 0; }
.divider{
  border: none;
  border-top: 1px solid rgba(21,28,42,.12);
  margin: 12px 0;
}
.social{ display:flex; gap: 10px; flex-wrap:wrap; }

.faq{ display:grid; gap: 10px; }
.details summary{
  list-style: none;
}
.details summary::-webkit-details-marker{ display:none; }

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 1020px){
  .hero{ grid-template-columns: 1fr; }
  .cards{ grid-template-columns: 1fr; }
  .motivation-grid{ grid-template-columns: 1fr; }
  .quiz-grid{ grid-template-columns: 1fr; }
  .big-picture{ grid-template-columns: 1fr; }
  .map-view{ grid-template-columns: 1fr 1fr; }
  .goals-board{ grid-template-columns: 1fr; }
  .modes-grid{ grid-template-columns: 1fr 1fr; }
  .feed-grid{ grid-template-columns: 1fr; }
  .contact-grid{ grid-template-columns: 1fr; }
  .page-head{ grid-template-columns: 1fr; }
  .form-grid{ grid-template-columns: 1fr 1fr; }
  .quiz-options{ grid-template-columns: 1fr; }
  .step{ grid-template-columns: 1fr; }
  .step-actions{ flex-direction: row; flex-wrap:wrap; min-width: auto; }
  .reflection-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 520px){
  .amber-home,
  .amber-space,
  .amber-map,
  .amber-goals,
  .amber-refresh,
  .amber-contact{ padding: 14px 12px 18px; }

  .hero-title{ font-size: 34px; }
  .page-title{ font-size: 30px; }
  .topbar{ position: static; }
}
