@import url("https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Lora:ital,wght@0,400;0,600;1,400&family=Playfair+Display:ital,wght@0,400;1,400&display=swap");

:root {
  --kg-black:    #0a0c0e;
  --kg-deep:     #111418;
  --kg-surface:  #181d22;
  --kg-glass:    rgba(255,255,255,0.04);
  --kg-border:   rgba(161,196,153,0.12);
  --kg-text:     #d4d4cc;
  --kg-muted:    #757575;
  --kg-fern:     #a1c499;
  --kg-mountain: #5a7d63;
  --kg-gold:     #f7e3a0;
  --kg-amber:    #e0a96d;
  --kg-shadow:   rgba(0,0,0,0.7);
  --font-head:   "Cinzel", serif;
  --font-body:   "Lora", serif;
  --font-accent: "Playfair Display", serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
::selection{background:rgba(161,196,153,0.25);color:#fff}
::-moz-selection{background:rgba(161,196,153,0.25);color:#fff}
body{font-family:var(--font-body);background:var(--kg-black);color:var(--kg-text);font-size:18px;line-height:1.85;min-height:100vh;position:relative;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:-1;background:radial-gradient(ellipse at 25% 85%,rgba(161,196,153,0.03) 0%,transparent 50%),radial-gradient(ellipse at 75% 15%,rgba(247,227,160,0.02) 0%,transparent 45%),radial-gradient(ellipse at 50% 100%,rgba(90,125,99,0.03) 0%,transparent 35%);animation:kg-shore-wash 30s ease-in-out infinite}
@keyframes kg-shore-wash{0%,100%{opacity:.5;transform:scaleX(1)}50%{opacity:.85;transform:scaleX(1.06)}}
img{max-width:100%;height:auto;display:block}
a{color:var(--kg-fern);text-decoration:none;transition:color .2s}
a:hover{color:var(--kg-gold)}

/* ── Layout ─────────────────────────────────────────────────────── */
.container{max-width:1100px;margin:0 auto;padding:0 24px}
.container--narrow{max-width:760px;margin:0 auto;padding:0 24px}

/* ── Nav ─────────────────────────────────────────────────────────── */
.kg-nav{position:sticky;top:0;z-index:100;background:rgba(10,12,14,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--kg-border)}
.kg-nav__inner{display:flex;align-items:center;justify-content:space-between;height:60px;max-width:1100px;margin:0 auto;padding:0 24px}
.kg-nav__logo{font-family:var(--font-head);font-size:1rem;letter-spacing:.12em;color:var(--kg-fern);text-decoration:none;text-transform:uppercase}
.kg-nav__logo span{color:var(--kg-gold)}
.kg-nav__links{display:flex;gap:28px;list-style:none}
.kg-nav__links a{font-family:var(--font-head);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--kg-muted);transition:color .2s}
.kg-nav__links a:hover{color:var(--kg-fern)}
.kg-nav__toggle{display:none;background:none;border:none;color:var(--kg-fern);font-size:1.4rem;cursor:pointer}
@media(max-width:768px){
  .kg-nav__links{display:none;position:absolute;top:60px;left:0;right:0;background:rgba(10,12,14,.97);flex-direction:column;padding:20px 24px;gap:16px;border-bottom:1px solid var(--kg-border)}
  .kg-nav__links.is-open{display:flex}
  .kg-nav__toggle{display:block}
}

/* ── Hero ────────────────────────────────────────────────────────── */
.kg-hero{position:relative;min-height:90vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:linear-gradient(180deg,#0a0c0e 0%,#0d1810 50%,#0a0c0e 100%)}
.kg-hero__bg{position:absolute;inset:0;background-image:url('/images/hero-napali.webp');background-size:cover;background-position:center;opacity:.22;filter:saturate(1.2)}
.kg-hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,12,14,.4) 0%,rgba(10,12,14,.6) 60%,rgba(10,12,14,.95) 100%)}
.kg-hero__glow{position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 40%,rgba(161,196,153,.06) 0%,transparent 60%),radial-gradient(ellipse 40% 80% at 20% 80%,rgba(10,12,14,.9) 0%,transparent 70%);animation:kg-hero-breathe 10s ease-in-out infinite}
@keyframes kg-hero-breathe{0%,100%{opacity:1}50%{opacity:.6}}
.kg-hero__content{position:relative;z-index:1;max-width:780px;padding:0 24px}
.kg-hero__eyebrow{display:block;font-family:var(--font-head);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--kg-fern);margin-bottom:20px}
.kg-hero__title{font-family:var(--font-head);font-size:clamp(2rem,6vw,3.8rem);color:#fff;line-height:1.15;text-shadow:0 2px 20px var(--kg-shadow);margin-bottom:24px;background:linear-gradient(135deg,#fff 0%,var(--kg-text) 60%,var(--kg-fern) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.kg-hero__title em{font-style:normal;color:var(--kg-fern)}
.kg-hero__sub{font-size:1.15rem;color:rgba(212,212,204,.7);font-style:italic;max-width:540px;margin:0 auto 36px;line-height:1.7}
.kg-hero__ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ── Buttons ─────────────────────────────────────────────────────── */
.kg-btn{display:inline-block;font-family:var(--font-head);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;padding:13px 28px;border-radius:9999px;transition:all .25s;cursor:pointer;border:none}
.kg-btn--primary{background:var(--kg-mountain);color:#fff;box-shadow:0 4px 16px rgba(90,125,99,.35),0 0 1px rgba(161,196,153,.1)}
.kg-btn--primary:hover{background:var(--kg-fern);color:var(--kg-black);box-shadow:0 8px 32px rgba(161,196,153,.45),0 0 2px rgba(161,196,153,.2);transform:translateY(-2px)}
.kg-btn--outline{background:transparent;color:var(--kg-fern);border:1px solid rgba(161,196,153,.4)}
.kg-btn--outline:hover{border-color:var(--kg-fern);background:rgba(161,196,153,.06);transform:translateY(-2px)}
.kg-btn--gold{background:var(--kg-amber);color:#3d1f0a}
.kg-btn--gold:hover{background:var(--kg-gold)}

/* ── Section ─────────────────────────────────────────────────────── */
.kg-section{padding:80px 0}
.kg-section--sm{padding:48px 0}
.kg-section--dark{background:var(--kg-deep)}
.kg-section__label{display:block;font-family:var(--font-head);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--kg-fern);margin-bottom:12px}
.kg-section__title{font-family:var(--font-head);font-size:clamp(1.5rem,3.5vw,2.4rem);color:#e8e8e0;margin-bottom:16px;line-height:1.25}
.kg-section__lead{font-size:1.05rem;color:rgba(212,212,204,.65);max-width:620px;font-style:italic;line-height:1.75;margin-bottom:36px}
.kg-section__title--centered{margin-left:auto;margin-right:auto;max-width:680px}
.kg-section__lead--centered{margin-left:auto;margin-right:auto}

/* ── Radio embed ─────────────────────────────────────────────────── */
.kg-radio-embed{max-width:680px;margin:0 auto 20px}
.kg-radio-embed iframe{width:100%;height:150px;border-radius:10px;background:#111;display:block}

/* ── Glass Card ──────────────────────────────────────────────────── */
.kg-card{background:var(--kg-glass);border:1px solid var(--kg-border);border-radius:14px;backdrop-filter:blur(12px) saturate(1.4);overflow:hidden;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s,border-color .3s;position:relative}
.kg-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(161,196,153,.35),transparent);opacity:0;transition:opacity .3s}
.kg-card:hover{transform:translateY(-5px);box-shadow:0 16px 48px rgba(0,0,0,.5);border-color:rgba(161,196,153,.25)}
.kg-card:hover::before{opacity:1}
.kg-card__img{width:100%;height:220px;object-fit:cover;opacity:.85;transition:transform .6s ease,opacity .3s}
.kg-card:hover .kg-card__img{transform:scale(1.05);opacity:.95}
.kg-card__body{padding:24px}
.kg-card__cat{font-family:var(--font-head);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--kg-amber);margin-bottom:8px;display:block}
.kg-card__title{font-family:var(--font-head);font-size:1.05rem;color:#e8e8e0;margin-bottom:10px;line-height:1.35}
.kg-card__excerpt{font-size:.9rem;color:var(--kg-muted);line-height:1.7}
.kg-card__link{display:inline-block;margin-top:14px;font-family:var(--font-head);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--kg-fern)}

/* ── Grid ────────────────────────────────────────────────────────── */
.kg-grid{display:grid;gap:28px}
.kg-grid--3{grid-template-columns:repeat(3,1fr)}
.kg-grid--2{grid-template-columns:repeat(2,1fr)}
@media(max-width:900px){.kg-grid--3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.kg-grid--3,.kg-grid--2{grid-template-columns:1fr}}

/* ── Feature strip ───────────────────────────────────────────────── */
.kg-feature{display:flex;gap:20px;align-items:flex-start;padding:28px;background:var(--kg-glass);border:1px solid var(--kg-border);border-radius:12px;backdrop-filter:blur(8px);transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;overflow:hidden}
.kg-feature::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(161,196,153,.3),transparent);opacity:0;transition:opacity .3s}
.kg-feature:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,.35);border-color:rgba(161,196,153,.2)}
.kg-feature:hover::before{opacity:1}
.kg-feature__icon{font-size:1.8rem;flex-shrink:0;line-height:1}
.kg-feature__title{font-family:var(--font-head);font-size:.95rem;color:var(--kg-fern);margin-bottom:6px}
.kg-feature__text{font-size:.9rem;color:var(--kg-muted);line-height:1.7}

/* ── Post / Page content ─────────────────────────────────────────── */
.kg-content{padding:60px 0 80px}
.kg-post__header{padding:60px 0 36px;text-align:center;border-bottom:1px solid var(--kg-border);margin-bottom:48px}
.kg-post__cat{font-family:var(--font-head);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--kg-amber);display:block;margin-bottom:16px}
.kg-post__title{font-family:var(--font-head);font-size:clamp(1.6rem,4vw,2.8rem);color:#f0efea;line-height:1.2;margin-bottom:16px}
.kg-post__date{font-size:.85rem;color:var(--kg-muted);font-style:italic}
.kg-post__image{width:100%;max-height:500px;object-fit:cover;border-radius:10px;margin-bottom:40px;opacity:.9}
.kg-prose{font-size:1.05rem;line-height:1.9;color:var(--kg-text)}
.kg-prose h2{font-family:var(--font-head);font-size:1.35rem;color:var(--kg-fern);margin:40px 0 16px}
.kg-prose h3{font-family:var(--font-head);font-size:1.1rem;color:var(--kg-gold);margin:32px 0 12px}
.kg-prose p{margin-bottom:22px}
.kg-prose a{color:var(--kg-fern);border-bottom:1px solid rgba(161,196,153,.3)}
.kg-prose a:hover{color:var(--kg-gold);border-color:rgba(247,227,160,.4)}
.kg-prose blockquote{border-left:3px solid var(--kg-mountain);padding:12px 20px;margin:28px 0;font-style:italic;color:rgba(212,212,204,.65);font-size:1.05rem}
.kg-prose ul,.kg-prose ol{padding-left:24px;margin-bottom:20px}
.kg-prose li{margin-bottom:8px}
.kg-prose strong{color:#e8e8e0;font-weight:600}
.kg-prose em{color:rgba(212,212,204,.85)}
.kg-prose hr{border:none;border-top:1px solid var(--kg-border);margin:40px 0}
.kg-prose table{width:100%;border-collapse:collapse;margin:28px 0;font-size:.92rem}
.kg-prose th{font-family:var(--font-head);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--kg-fern);text-align:left;padding:12px 16px;border-bottom:2px solid var(--kg-border);background:rgba(161,196,153,.04)}
.kg-prose td{padding:12px 16px;border-bottom:1px solid var(--kg-border);color:var(--kg-text);vertical-align:top}
.kg-prose tr:hover td{background:rgba(161,196,153,.03)}
.kg-prose img{border-radius:10px;margin:28px 0}
.kg-prose code{font-family:'IBM Plex Mono','SF Mono',monospace;font-size:0.88em;color:var(--kg-fern);background:rgba(161,196,153,0.06);padding:0.15em 0.4em;border-radius:4px}
.kg-prose pre{background:rgba(10,12,14,0.9);border:1px solid var(--kg-border);border-radius:10px;padding:18px 20px;overflow-x:auto;margin:24px 0;font-size:0.85rem;line-height:1.6}
.kg-prose pre code{background:none;padding:0;color:var(--kg-text);font-size:inherit}
.kg-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:36px;padding-top:28px;border-top:1px solid var(--kg-border)}
.kg-tag{font-family:var(--font-head);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;padding:5px 12px;border:1px solid var(--kg-border);border-radius:9999px;color:var(--kg-muted)}
.kg-tag:hover{border-color:var(--kg-fern);color:var(--kg-fern)}

/* ── Category badge ──────────────────────────────────────────────── */
.kg-cat-badge{display:inline-block;font-family:var(--font-head);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;padding:4px 10px;border-radius:9999px;background:rgba(161,196,153,.1);border:1px solid rgba(161,196,153,.2);color:var(--kg-fern)}

/* ── List header ─────────────────────────────────────────────────── */
.kg-list-header{padding:64px 0 40px;text-align:center;border-bottom:1px solid var(--kg-border)}
.kg-pagination{display:flex;justify-content:center;gap:12px;padding:48px 0 20px}
.kg-pagination a{font-family:var(--font-head);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:10px 20px;border:1px solid var(--kg-border);border-radius:9999px;color:var(--kg-muted)}
.kg-pagination a:hover{border-color:var(--kg-fern);color:var(--kg-fern)}

/* ── Newsletter ──────────────────────────────────────────────────── */
.kg-nl{background:rgba(17,20,24,0.85);backdrop-filter:blur(12px) saturate(1.3);-webkit-backdrop-filter:blur(12px) saturate(1.3);border-top:1px solid var(--kg-border);border-bottom:1px solid var(--kg-border);padding:72px 24px;text-align:center}
.kg-nl__inner{max-width:520px;margin:0 auto}
.kg-nl__label{font-family:var(--font-head);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--kg-fern);display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px}
.kg-nl__pulse{width:6px;height:6px;background:var(--kg-fern);border-radius:50%;animation:kg-pulse 2.5s ease-in-out infinite}
@keyframes kg-pulse{0%,100%{opacity:1}50%{opacity:.3}}
.kg-nl__title{font-family:var(--font-head);font-size:1.6rem;color:#f0efea;margin-bottom:12px}
.kg-nl__copy{font-size:.95rem;color:var(--kg-muted);line-height:1.75;margin-bottom:28px;font-style:italic}
.kg-nl__form{display:flex;gap:10px;max-width:400px;margin:0 auto 12px;flex-wrap:wrap}
.kg-nl__input{flex:1;min-width:0;background:rgba(255,255,255,.04);border:1px solid rgba(161,196,153,.2);border-radius:4px;padding:12px 16px;color:var(--kg-text);font-family:var(--font-body);font-size:.9rem;outline:none;transition:border-color .2s}
.kg-nl__input:focus{border-color:rgba(161,196,153,.5)}
.kg-nl__input::placeholder{color:rgba(117,117,117,.6)}
.kg-nl__btn{background:var(--kg-mountain);color:#fff;font-family:var(--font-head);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;border:none;border-radius:4px;padding:12px 20px;cursor:pointer;transition:background .2s;white-space:nowrap}
.kg-nl__btn:hover{background:var(--kg-fern);color:var(--kg-black)}
.kg-nl__status{display:block;min-height:20px;font-size:.85rem;margin-bottom:8px;font-style:italic}
.kg-nl__status--ok{color:var(--kg-fern)}
.kg-nl__status--err{color:#c07070}
.kg-nl__note{font-size:.72rem;color:rgba(117,117,117,.5);font-family:var(--font-head);letter-spacing:.06em}

/* ── Footer ──────────────────────────────────────────────────────── */
.kg-footer{background:var(--kg-deep);border-top:1px solid var(--kg-border);padding:48px 0 28px}
.kg-footer__inner{display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.kg-footer__brand .kg-footer__logo{font-family:var(--font-head);font-size:1rem;letter-spacing:.1em;color:var(--kg-fern);text-transform:uppercase}
.kg-footer__brand p{font-size:.85rem;color:var(--kg-muted);margin-top:8px;line-height:1.6;font-style:italic}
.kg-footer__col h4{font-family:var(--font-head);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--kg-fern);margin-bottom:14px}
.kg-footer__col ul{list-style:none}
.kg-footer__col li{margin-bottom:8px}
.kg-footer__col a{font-size:.88rem;color:var(--kg-muted)}
.kg-footer__col a:hover{color:var(--kg-fern)}
.kg-footer__social{display:flex;gap:14px;margin-top:16px}
.kg-footer__social a{color:var(--kg-muted);font-size:1.1rem;transition:color .2s}
.kg-footer__social a:hover{color:var(--kg-fern)}
.kg-footer__bottom{border-top:1px solid var(--kg-border);padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.kg-footer__copy{font-size:.78rem;color:rgba(117,117,117,.5);font-family:var(--font-head);letter-spacing:.06em}
.kg-footer__forged{font-size:.8rem;color:rgba(161,196,153,.35);font-style:italic}
@media(max-width:768px){
  .kg-footer__inner{grid-template-columns:1fr}
  .kg-footer__bottom{flex-direction:column;text-align:center}
}

/* ── Moʻolelo category menu ──────────────────────────────────────── */
.kg-lib-cats{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:40px;justify-content:center}
.kg-lib-cat{font-family:var(--font-head);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;padding:8px 16px;border:1px solid var(--kg-border);border-radius:9999px;color:var(--kg-muted);transition:all .2s}
.kg-lib-cat:hover,.kg-lib-cat.is-active{border-color:var(--kg-fern);color:var(--kg-fern);background:rgba(161,196,153,.06)}

/* ── Mission strip ───────────────────────────────────────────────── */
.kg-mission{background:linear-gradient(135deg,#0d1810 0%,#111a14 100%);border:1px solid rgba(161,196,153,.1);border-radius:16px;padding:48px;text-align:center;margin:40px 0;backdrop-filter:blur(8px);position:relative;overflow:hidden}
.kg-mission::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(161,196,153,.04) 0%,transparent 70%);pointer-events:none}
.kg-mission blockquote{font-family:var(--font-accent);font-size:clamp(1.2rem,2.5vw,1.7rem);color:var(--kg-gold);font-style:italic;line-height:1.5;max-width:680px;margin:0 auto}

/* ── Breadcrumb ──────────────────────────────────────────────────── */
.kg-breadcrumb{font-family:var(--font-head);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--kg-muted);padding:20px 0 0}
.kg-breadcrumb a{color:var(--kg-muted)}
.kg-breadcrumb a:hover{color:var(--kg-fern)}
.kg-breadcrumb span{margin:0 8px;opacity:.4}

/* ── 404 ─────────────────────────────────────────────────────────── */
.kg-404{text-align:center;padding:120px 24px}
.kg-404__title{font-family:var(--font-head);font-size:clamp(2rem,6vw,4rem);color:var(--kg-fern);margin-bottom:16px}
.kg-404__text{color:var(--kg-muted);font-style:italic;margin-bottom:32px}

/* ── Utility ─────────────────────────────────────────────────────── */
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
.text-center{text-align:center}
.mt-lg{margin-top:60px}
.mt-md{margin-top:36px}

/* ── Reveal animation ────────────────────────────────────────────── */
.kg-reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.kg-reveal.is-visible{opacity:1;transform:translateY(0)}

/* ══════════════════════════════════════════════════════════════════
   DAYPART — Atmospheric time-of-day shifts (Hawaii time)
   Applied via body.dp-{dawn|morning|midday|golden|night}
   ══════════════════════════════════════════════════════════════════ */

/* ── Dawn  5–7am  — lavender mist, first light through the valley ── */
body.dp-dawn{
  --kg-black:#0e0a10;--kg-deep:#13101a;--kg-surface:#1a1520;
  --kg-fern:#c4a8d0;--kg-mountain:#8a6b96;--kg-gold:#e8c4a0;--kg-amber:#d4a888;
  --kg-border:rgba(196,168,208,.12);--kg-glass:rgba(196,168,208,.03)
}
body.dp-dawn .kg-hero{background:linear-gradient(180deg,#0e0a10 0%,#1a1020 40%,#2a1830 70%,#0e0a10 100%)}
body.dp-dawn .kg-hero__bg{opacity:.18;filter:saturate(.8) hue-rotate(-15deg)}
body.dp-dawn .kg-nav{background:rgba(14,10,16,.92)}
body.dp-dawn .kg-section--dark{background:#13101a}
body.dp-dawn .kg-nl{background:#13101a}
body.dp-dawn .kg-footer{background:#13101a}

/* ── Morning  7am–12pm  — fresh fern light, trade winds ──────────── */
body.dp-morning{
  --kg-black:#080e0a;--kg-deep:#0e160f;--kg-surface:#142018;
  --kg-fern:#8ec48a;--kg-mountain:#4e8a52;--kg-gold:#d4e0a0;--kg-amber:#a8c870;
  --kg-border:rgba(142,196,138,.14);--kg-glass:rgba(142,196,138,.04)
}
body.dp-morning .kg-hero{background:linear-gradient(180deg,#080e0a 0%,#0e180e 40%,#142418 70%,#080e0a 100%)}
body.dp-morning .kg-hero__bg{opacity:.25;filter:saturate(1.3) brightness(1.05)}
body.dp-morning .kg-nav{background:rgba(8,14,10,.92)}
body.dp-morning .kg-section--dark{background:#0e160f}
body.dp-morning .kg-nl{background:#0e160f}
body.dp-morning .kg-footer{background:#0e160f}

/* ── Midday  12–4pm  — high sun, bright valley, warm neutral ─────── */
body.dp-midday{
  --kg-black:#0c0e0a;--kg-deep:#141810;--kg-surface:#1c2218;
  --kg-fern:#b8d4a0;--kg-mountain:#6a9458;--kg-gold:#f0e0a8;--kg-amber:#d8c060;
  --kg-text:#deded6;
  --kg-border:rgba(184,212,160,.14);--kg-glass:rgba(184,212,160,.04)
}
body.dp-midday .kg-hero{background:linear-gradient(180deg,#0c0e0a 0%,#141c10 40%,#1e2a18 70%,#0c0e0a 100%)}
body.dp-midday .kg-hero__bg{opacity:.30;filter:saturate(1.4) brightness(1.1)}
body.dp-midday .kg-nav{background:rgba(12,14,10,.90)}
body.dp-midday .kg-section--dark{background:#141810}
body.dp-midday .kg-nl{background:#141810}
body.dp-midday .kg-footer{background:#141810}

/* ── Golden  4–7pm  — amber sunset, cliffs on fire ───────────────── */
body.dp-golden{
  --kg-black:#100c08;--kg-deep:#1a1410;--kg-surface:#241c14;
  --kg-fern:#d4a868;--kg-mountain:#a07840;--kg-gold:#f7d080;--kg-amber:#e8b050;
  --kg-border:rgba(212,168,104,.15);--kg-glass:rgba(212,168,104,.04)
}
body.dp-golden .kg-hero{background:linear-gradient(180deg,#100c08 0%,#1e1408 40%,#2e1c0a 70%,#100c08 100%)}
body.dp-golden .kg-hero__bg{opacity:.28;filter:saturate(1.5) hue-rotate(10deg) brightness(1.05)}
body.dp-golden .kg-nav{background:rgba(16,12,8,.92)}
body.dp-golden .kg-section--dark{background:#1a1410}
body.dp-golden .kg-nl{background:#1a1410}
body.dp-golden .kg-footer{background:#1a1410}
body.dp-golden .kg-mission blockquote{color:#f0c870}

/* ── Night  7pm–5am  — deep volcanic default (base state) ────────── */
body.dp-night{
  --kg-black:#0a0c0e;--kg-deep:#111418;--kg-surface:#181d22;
  --kg-fern:#a1c499;--kg-mountain:#5a7d63;--kg-gold:#f7e3a0;--kg-amber:#e0a96d
}
body.dp-night .kg-hero__bg{opacity:.15;filter:saturate(1) brightness(.9)}

/* ── Smooth daypart transitions ──────────────────────────────────── */
body,body .kg-nav,body .kg-hero,body .kg-section--dark,body .kg-nl,body .kg-footer{
  transition:background-color 2s ease,color 1.5s ease
}
.kg-hero__bg{transition:opacity 2s ease,filter 2s ease}
.kg-mission blockquote{transition:color 2s ease}

/* ── Reduced Motion ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important}
}
