/* v=1777569869325 */
/* Kinoko Hachijo — main stylesheet */
:root{
  --kn-bg:#0a1410; --kn-bg-2:#0f1d18; --kn-bg-3:#142a22;
  --kn-fg:#f3f7f2; --kn-fg-mute:rgba(243,247,242,.65); --kn-fg-dim:rgba(243,247,242,.45);
  --kn-line:rgba(243,247,242,.10); --kn-line-2:rgba(243,247,242,.18);
  --kn-card:rgba(255,255,255,.03); --kn-card-2:rgba(255,255,255,.05);
  --kn-accent:#2D6A4F; --kn-accent-2:#1A5C3A;
  --kn-glow:#B5E48C; --kn-glow-strong:#6BD968;
  --kn-line-color:#06C755;
  --kn-radius:18px; --kn-radius-sm:12px; --kn-radius-lg:28px;
  --kn-font-sans:'Zen Kaku Gothic New','Noto Sans JP','Hiragino Kaku Gothic ProN','Yu Gothic',sans-serif;
  --kn-font-serif:'Noto Serif JP','Yu Mincho',serif;
  --kn-font-mono:'JetBrains Mono',ui-monospace,'SF Mono',monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--kn-font-sans);background:var(--kn-bg);color:var(--kn-fg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:'palt' 1;line-height:1.7;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}

.kn-container{max-width:1140px;margin:0 auto;padding:0 24px}

/* Header */
.kn-header{position:sticky;top:0;z-index:50;background:rgba(10,20,16,.72);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--kn-line)}
.kn-header-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:68px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.kn-logo{display:flex;align-items:center;gap:10px;color:var(--kn-fg)}
.kn-logo-mark{width:38px;height:38px;border-radius:50%;background:radial-gradient(circle at 50% 60%,var(--kn-glow) 0%,var(--kn-accent) 70%);display:grid;place-items:center;color:var(--kn-bg);box-shadow:0 0 20px rgba(181,228,140,.35)}
.kn-logo-text{display:flex;flex-direction:column;line-height:1.1}
.kn-logo-jp{font-weight:700;font-size:15px;letter-spacing:.04em}
.kn-logo-en{font-size:10px;letter-spacing:.18em;color:var(--kn-fg-dim);font-family:var(--kn-font-mono);margin-top:2px}
.kn-nav-desktop{display:flex;align-items:center;gap:6px}
.kn-nav-link{padding:10px 14px;font-size:13.5px;font-weight:500;color:var(--kn-fg-mute);border-radius:999px;transition:color .2s,background .2s}
.kn-nav-link:hover{color:var(--kn-fg);background:rgba(255,255,255,.05)}
.kn-nav-link.is-active{color:var(--kn-glow)}
.kn-line-pill{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;background:var(--kn-line-color);color:#fff;border-radius:999px;font-size:13px;font-weight:700;margin-left:8px;transition:transform .2s,box-shadow .2s}
.kn-line-pill:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(6,199,85,.35)}
.kn-burger{display:none;flex-direction:column;gap:5px;padding:8px}
.kn-burger span{display:block;width:22px;height:2px;background:var(--kn-fg);border-radius:2px;transition:transform .2s,opacity .2s}
.kn-nav-mobile{display:flex;flex-direction:column;padding:8px 24px 20px;gap:4px;border-top:1px solid var(--kn-line)}
.kn-nav-link-m{padding:14px 0;font-size:16px;color:var(--kn-fg);border-bottom:1px solid var(--kn-line)}
@media (max-width:880px){
  .kn-nav-desktop{display:none}
  .kn-burger{display:flex}
}

/* Hero */
.kn-hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;isolation:isolate}
.kn-hero-bg{position:absolute;inset:0;z-index:-2}
.kn-hero-bg img{width:100%;height:100%;object-fit:cover;filter:saturate(115%) contrast(108%)}
.kn-hero-veil{position:absolute;inset:0;background:radial-gradient(60% 60% at 30% 50%,rgba(10,20,16,0) 0%,rgba(10,20,16,.5) 70%,rgba(10,20,16,.85) 100%),linear-gradient(to bottom,rgba(10,20,16,.55) 0%,rgba(10,20,16,.25) 35%,rgba(10,20,16,.85) 100%)}
.kn-hero-stars{position:absolute;inset:0;z-index:-1;pointer-events:none}
.kn-spore{position:absolute;border-radius:50%;background:var(--kn-glow);box-shadow:0 0 8px var(--kn-glow),0 0 16px rgba(181,228,140,.4);animation:kn-float-spore ease-in-out infinite}
@keyframes kn-float-spore{0%,100%{transform:translateY(0) scale(1);opacity:.4}50%{transform:translateY(-30px) scale(1.4);opacity:1}}
.kn-hero-content{position:relative;z-index:1;width:100%;max-width:1140px;margin:0 auto;padding:80px 24px 120px}
.kn-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--kn-font-mono);font-size:11px;letter-spacing:.32em;color:var(--kn-glow);margin:0 0 28px;padding:6px 14px;background:rgba(181,228,140,.08);border:1px solid rgba(181,228,140,.25);border-radius:999px;text-transform:uppercase}
.kn-pulse{width:7px;height:7px;border-radius:50%;background:var(--kn-glow);box-shadow:0 0 10px var(--kn-glow);animation:kn-pulse 2s ease-in-out infinite}
@keyframes kn-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.5}}
.kn-hero-title{font-family:var(--kn-font-serif);font-weight:700;font-size:clamp(40px,7vw,84px);line-height:1.1;letter-spacing:.01em;margin:0 0 24px}
.kn-hero-title span{display:block}
.kn-glow-text{background:linear-gradient(120deg,var(--kn-glow) 0%,#d8ffaa 50%,var(--kn-glow-strong) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 24px rgba(181,228,140,.4))}
.kn-hero-lead{font-size:clamp(15px,1.6vw,18px);color:rgba(243,247,242,.85);margin:0 0 40px;max-width:540px;line-height:1.9}
.kn-hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.kn-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;font-size:14.5px;font-weight:700;border-radius:999px;border:1px solid transparent;transition:transform .2s,box-shadow .2s,background .2s}
.kn-btn:hover{transform:translateY(-2px)}
.kn-btn-primary{background:var(--kn-glow);color:var(--kn-bg);box-shadow:0 8px 26px rgba(181,228,140,.3)}
.kn-btn-primary:hover{box-shadow:0 12px 34px rgba(181,228,140,.5);background:#d8ffaa}
.kn-btn-line{background:var(--kn-line-color);color:#fff}
.kn-btn-line:hover{box-shadow:0 12px 34px rgba(6,199,85,.4)}
.kn-btn-line-white{background:#fff;color:var(--kn-line-color)}
.kn-scroll-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);width:24px;height:38px;border:1.5px solid rgba(255,255,255,.4);border-radius:999px;display:grid;place-items:start center;padding-top:8px}
.kn-scroll-hint span{display:block;width:3px;height:8px;background:var(--kn-glow);border-radius:2px;animation:kn-scroll 1.8s ease-in-out infinite}
@keyframes kn-scroll{0%{transform:translateY(0);opacity:1}100%{transform:translateY(14px);opacity:0}}

/* Section common */
.kn-section{padding:110px 0;position:relative}
.kn-about,.kn-where,.kn-news{background:var(--kn-bg-2)}
.kn-section-head{display:grid;grid-template-columns:auto 1fr auto;align-items:end;column-gap:18px;margin-bottom:56px}
.kn-kicker{font-family:var(--kn-font-mono);font-size:11px;letter-spacing:.28em;color:var(--kn-glow);grid-column:1/2;grid-row:1;align-self:end;padding-bottom:6px}
.kn-h2{grid-column:2/3;grid-row:1;font-family:var(--kn-font-serif);font-size:clamp(28px,3.6vw,44px);font-weight:700;margin:0;line-height:1.2}
.kn-section-sub{grid-column:2/4;grid-row:2;margin:14px 0 0;color:var(--kn-fg-mute);font-size:14.5px}
.kn-section-link{grid-column:3/4;grid-row:1;font-size:13px;color:var(--kn-glow);font-weight:600}
@media (max-width:720px){
  .kn-section{padding:80px 0}
  .kn-section-head{grid-template-columns:1fr}
  .kn-kicker,.kn-h2,.kn-section-sub,.kn-section-link{grid-column:1;grid-row:auto}
}

/* About */
.kn-about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:start}
.kn-lead{font-size:clamp(17px,1.9vw,21px);line-height:1.85;color:var(--kn-fg);margin:0 0 24px}
.kn-drop{float:left;font-family:var(--kn-font-serif);font-size:56px;line-height:.9;margin:4px 8px 0 0;color:var(--kn-glow);text-shadow:0 0 24px rgba(181,228,140,.4)}
.kn-body{color:var(--kn-fg-mute);margin:0 0 36px;line-height:1.95}
.kn-body em{color:var(--kn-glow);font-style:normal;font-weight:600}
.kn-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--kn-line);border-radius:var(--kn-radius);overflow:hidden;border:1px solid var(--kn-line)}
.kn-stat{padding:22px 18px;background:var(--kn-bg-2)}
.kn-stat-num{font-family:var(--kn-font-serif);font-size:clamp(26px,3vw,38px);font-weight:700;color:var(--kn-glow);line-height:1}
.kn-stat-num span{font-family:var(--kn-font-sans);font-size:14px;color:var(--kn-fg-mute);margin-left:4px;font-weight:500}
.kn-stat-label{font-size:12px;color:var(--kn-fg-mute);margin-top:8px;letter-spacing:.05em}
.kn-about-fig{margin:0;position:relative;border-radius:var(--kn-radius);overflow:hidden;background:#000}
.kn-about-fig img{width:100%;aspect-ratio:4/5;object-fit:cover}
.kn-about-fig figcaption{position:absolute;bottom:0;left:0;right:0;padding:16px 20px;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);font-size:12.5px;color:rgba(255,255,255,.85);font-family:var(--kn-font-mono);letter-spacing:.05em}
@media (max-width:880px){.kn-about-grid{grid-template-columns:1fr;gap:40px}}

/* Season */
.kn-month-card{background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius-lg);padding:36px}
.kn-month-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:8px}
.kn-month{position:relative;aspect-ratio:1/1.15;background:rgba(255,255,255,.04);border:1px solid var(--kn-line);border-radius:14px;color:var(--kn-fg-mute);font-family:var(--kn-font-sans);display:flex;flex-direction:column;justify-content:center;align-items:center;transition:transform .2s,background .2s,border-color .2s}
.kn-month-num{font-family:var(--kn-font-serif);font-size:clamp(18px,2vw,24px);font-weight:700;line-height:1}
.kn-month-lbl{font-size:10px;margin-top:4px;letter-spacing:.1em;opacity:.7}
.kn-month:hover{transform:translateY(-3px);background:rgba(255,255,255,.08)}
.kn-month.kn-tier-pre{background:rgba(181,228,140,.06);border-color:rgba(181,228,140,.18);color:rgba(181,228,140,.7)}
.kn-month.kn-tier-season{background:rgba(45,106,79,.4);border-color:rgba(45,106,79,.7);color:#cbe9b8}
.kn-month.kn-tier-best{background:linear-gradient(160deg,rgba(181,228,140,.4),rgba(45,106,79,.5));border-color:var(--kn-glow);color:#fff;box-shadow:0 0 18px rgba(181,228,140,.25), inset 0 0 12px rgba(181,228,140,.15)}
.kn-month.is-active{outline:2px solid var(--kn-glow);outline-offset:2px;transform:translateY(-3px)}
.kn-month-dot{position:absolute;top:8px;right:8px;width:6px;height:6px;border-radius:50%;background:var(--kn-glow);box-shadow:0 0 8px var(--kn-glow);animation:kn-pulse 2s ease-in-out infinite}
@media (max-width:720px){
  .kn-month-card{padding:20px}
  .kn-month-grid{grid-template-columns:repeat(6,1fr)}
}
.kn-legend{display:flex;flex-wrap:wrap;gap:18px;margin:20px 0 4px;font-size:12px;color:var(--kn-fg-mute)}
.kn-legend span{display:inline-flex;align-items:center;gap:8px}
.kn-sw{display:inline-block;width:16px;height:10px;border-radius:4px;border:1px solid var(--kn-line)}
.kn-sw.kn-tier-best{background:linear-gradient(160deg,rgba(181,228,140,.6),rgba(45,106,79,.7));border-color:var(--kn-glow)}
.kn-sw.kn-tier-season{background:rgba(45,106,79,.5)}
.kn-sw.kn-tier-pre{background:rgba(181,228,140,.12)}
.kn-sw.kn-tier-off{background:rgba(255,255,255,.05)}
.kn-month-detail{margin-top:24px;padding:24px;border-radius:var(--kn-radius);background:rgba(255,255,255,.03);border:1px solid var(--kn-line);animation:kn-fade .35s ease both}
@keyframes kn-fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.kn-md-head{display:flex;align-items:center;gap:18px;margin-bottom:10px}
.kn-md-num{font-family:var(--kn-font-serif);font-size:48px;font-weight:700;line-height:1;color:var(--kn-glow);min-width:60px;text-align:center}
.kn-md-title{font-size:18px;font-weight:700}
.kn-md-sub{font-size:12px;color:var(--kn-fg-mute);font-family:var(--kn-font-mono);letter-spacing:.1em;margin-top:2px}
.kn-md-body{color:var(--kn-fg-mute);margin:6px 0 16px;line-height:1.85}
.kn-md-cta{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--kn-glow);color:var(--kn-bg);border-radius:999px;font-weight:700;font-size:13px}
.kn-md-indoor{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.kn-indoor-card{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(255,255,255,.06);border:1px solid var(--kn-line);border-radius:999px;font-size:13px}
.kn-fineprint{margin:18px 0 0;font-size:12px;color:var(--kn-fg-dim)}
.kn-fineprint a{color:var(--kn-glow);text-decoration:underline;text-underline-offset:2px}

/* Where */
.kn-where-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:880px){.kn-where-grid{grid-template-columns:1fr}}
.kn-place{background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,border-color .25s}
.kn-place:hover{transform:translateY(-4px);border-color:rgba(181,228,140,.35)}
.kn-place-img{aspect-ratio:4/3;overflow:hidden;background:#000}
.kn-place-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.kn-place:hover .kn-place-img img{transform:scale(1.05)}
.kn-place-body{padding:22px}
.kn-place-tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--kn-glow);font-family:var(--kn-font-mono);letter-spacing:.1em;margin-bottom:10px;padding:4px 10px;background:rgba(181,228,140,.08);border-radius:999px}
.kn-place-title{font-family:var(--kn-font-serif);font-size:20px;font-weight:700;margin:0 0 8px}
.kn-place-text{color:var(--kn-fg-mute);margin:0 0 14px;font-size:14px;line-height:1.85}
.kn-place-cta{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--kn-glow)}

/* Safety */
.kn-warn{display:flex;gap:18px;padding:24px;background:rgba(255,184,107,.08);border:1px solid rgba(255,184,107,.3);border-radius:var(--kn-radius);margin-bottom:36px}
.kn-warn-icon{flex:0 0 auto;width:52px;height:52px;border-radius:50%;background:rgba(255,184,107,.18);display:grid;place-items:center;color:#ffb86b}
.kn-warn-body h3{margin:0 0 6px;font-size:17px;font-weight:700;color:#ffb86b}
.kn-warn-body p{margin:0;color:var(--kn-fg-mute);font-size:14px;line-height:1.8}
.kn-warn-body strong{color:var(--kn-fg)}
.kn-rules{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media (max-width:720px){.kn-rules{grid-template-columns:1fr}}
.kn-rules li{display:flex;gap:16px;padding:18px 20px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius-sm)}
.kn-rule-num{font-family:var(--kn-font-mono);font-size:13px;color:var(--kn-glow);letter-spacing:.1em;flex:0 0 auto;padding-top:2px}
.kn-rules strong{display:block;font-size:15px;font-weight:700;margin-bottom:2px}
.kn-rules span{font-size:13px;color:var(--kn-fg-mute)}

/* News */
.kn-news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:880px){.kn-news-grid{grid-template-columns:1fr}}
.kn-news-card{background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,border-color .25s}
.kn-news-card:hover{transform:translateY(-4px);border-color:rgba(181,228,140,.35)}
.kn-news-img{aspect-ratio:16/10;overflow:hidden;background:#000}
.kn-news-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.kn-news-card:hover .kn-news-img img{transform:scale(1.05)}
.kn-news-body{padding:22px;flex:1;display:flex;flex-direction:column}
.kn-news-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:12px;color:var(--kn-fg-dim);font-family:var(--kn-font-mono)}
.kn-tag{padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.04em}
.kn-tag-observation{background:rgba(181,228,140,.16);color:var(--kn-glow)}
.kn-tag-event{background:rgba(6,199,85,.18);color:#7be4a3}
.kn-tag-info{background:rgba(255,255,255,.08);color:var(--kn-fg-mute)}
.kn-news-title{font-size:16px;font-weight:700;margin:0 0 8px;line-height:1.55;text-wrap:pretty}
.kn-news-excerpt{color:var(--kn-fg-mute);font-size:13.5px;line-height:1.8;margin:0 0 14px;flex:1}
.kn-news-more{font-size:13px;font-weight:700;color:var(--kn-glow)}

/* FAQ */
.kn-faq-list{display:flex;flex-direction:column;gap:10px;max-width:840px;margin:0 auto}
.kn-faq-item{background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius-sm);overflow:hidden;transition:border-color .2s}
.kn-faq-item.is-open{border-color:rgba(181,228,140,.4)}
.kn-faq-q{display:flex;align-items:center;gap:14px;width:100%;padding:18px 22px;text-align:left;font-size:15px;font-weight:600;color:var(--kn-fg);transition:background .2s}
.kn-faq-q:hover{background:rgba(255,255,255,.03)}
.kn-faq-marker{flex:0 0 auto;width:30px;height:30px;border-radius:50%;background:rgba(181,228,140,.16);color:var(--kn-glow);display:grid;place-items:center;font-family:var(--kn-font-serif);font-weight:700;font-size:14px}
.kn-faq-marker-a{background:rgba(45,106,79,.4);color:#cbe9b8;margin-right:14px}
.kn-faq-text{flex:1}
.kn-faq-chev{flex:0 0 auto;color:var(--kn-fg-mute);transition:transform .25s}
.kn-faq-item.is-open .kn-faq-chev{transform:rotate(180deg);color:var(--kn-glow)}
.kn-faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease}
.kn-faq-item.is-open .kn-faq-a{grid-template-rows:1fr}
.kn-faq-a > div{overflow:hidden;display:flex;align-items:flex-start;color:var(--kn-fg-mute);font-size:14px;line-height:1.95;padding:0 22px}
.kn-faq-item.is-open .kn-faq-a > div{padding:4px 22px 22px}

/* LINE CTA */
.kn-line{background:linear-gradient(160deg,#082118 0%,#0a1410 100%)}
.kn-line-card{position:relative;border-radius:var(--kn-radius-lg);background:linear-gradient(135deg,#06C755 0%,#04a847 100%);overflow:hidden;padding:64px 40px;text-align:center;color:#fff;isolation:isolate}
.kn-line-glow{position:absolute;inset:-50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.25),transparent 50%);z-index:-1}
.kn-line-icon{display:inline-grid;place-items:center;width:80px;height:80px;border-radius:24px;background:rgba(255,255,255,.16);margin-bottom:20px}
.kn-line-title{font-family:var(--kn-font-serif);font-size:clamp(24px,3vw,34px);font-weight:700;margin:0 0 10px}
.kn-line-text{margin:0 0 28px;color:rgba(255,255,255,.92);font-size:15px}

/* Footer */
.kn-footer{background:#06100c;padding:60px 0 40px;border-top:1px solid var(--kn-line)}
.kn-footer-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-bottom:40px}
.kn-footer-brand{font-family:var(--kn-font-serif);font-size:20px;font-weight:700;margin-bottom:6px}
.kn-footer-tag{margin:0;color:var(--kn-fg-mute);font-size:13px}
.kn-footer-nav{display:flex;flex-wrap:wrap;gap:6px 22px}
.kn-footer-nav a{font-size:13px;color:var(--kn-fg-mute);transition:color .2s}
.kn-footer-nav a:hover{color:var(--kn-glow)}
.kn-footer-bot{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding-top:24px;border-top:1px solid var(--kn-line);font-size:12px;color:var(--kn-fg-dim)}
.kn-footer-links{display:flex;gap:18px}
.kn-footer-links a:hover{color:var(--kn-glow)}

/* ====== Page hero (sub pages) ====== */
.kn-page-hero{position:relative;padding:120px 0 60px;background:linear-gradient(180deg,#0a1410 0%,#0e1d17 100%);border-bottom:1px solid var(--kn-line);overflow:hidden}
.kn-page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(800px 320px at 20% 0%,rgba(181,228,140,.08),transparent 60%),radial-gradient(700px 280px at 90% 100%,rgba(45,106,79,.18),transparent 60%);pointer-events:none}
.kn-breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--kn-fg-mute);margin-bottom:18px;font-family:var(--kn-font-mono);letter-spacing:.05em}
.kn-breadcrumb a{color:var(--kn-fg-mute);transition:color .2s}
.kn-breadcrumb a:hover{color:var(--kn-glow)}
.kn-breadcrumb span[aria-current]{color:var(--kn-glow)}
.kn-page-title{font-family:var(--kn-font-serif);font-size:clamp(34px,5vw,58px);font-weight:700;line-height:1.15;margin:14px 0 18px;letter-spacing:.01em}
.kn-page-lead{font-size:clamp(15px,1.6vw,17px);color:var(--kn-fg-mute);max-width:640px;line-height:1.9;margin:0}

/* News page-specific */
.kn-news-filter{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.kn-filter-btn{padding:8px 16px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:999px;font-size:13px;color:var(--kn-fg-mute);transition:all .2s}
.kn-filter-btn:hover{color:var(--kn-fg);border-color:var(--kn-line-2)}
.kn-filter-btn.is-active{background:rgba(181,228,140,.14);border-color:rgba(181,228,140,.45);color:var(--kn-glow)}
.kn-news-archive{display:flex;flex-direction:column;gap:14px}
.kn-news-row{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:20px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius);transition:transform .25s,border-color .25s}
.kn-news-row:hover{transform:translateY(-2px);border-color:rgba(181,228,140,.35)}
.kn-news-row .kn-news-img{aspect-ratio:4/3;border-radius:var(--kn-radius-sm)}
@media (max-width:720px){.kn-news-row{grid-template-columns:1fr;gap:14px}}
.kn-news-row .kn-news-body{padding:0}

/* Tour page */
.kn-tour-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:36px 0 60px}
@media (max-width:720px){.kn-tour-stats{grid-template-columns:repeat(2,1fr)}}
.kn-tour-stat{padding:22px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius);text-align:center}
.kn-tour-stat-num{font-family:var(--kn-font-serif);font-size:clamp(22px,3vw,30px);font-weight:700;color:var(--kn-glow)}
.kn-tour-stat-lbl{font-size:11px;color:var(--kn-fg-mute);margin-top:6px;letter-spacing:.1em;font-family:var(--kn-font-mono)}

.kn-courses{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media (max-width:720px){.kn-courses{grid-template-columns:1fr}}
.kn-course{position:relative;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,border-color .25s}
.kn-course:hover{transform:translateY(-4px);border-color:rgba(181,228,140,.35)}
.kn-course.is-featured{border-color:rgba(181,228,140,.45);box-shadow:0 0 32px rgba(181,228,140,.08)}
.kn-course-img{aspect-ratio:16/9;overflow:hidden;background:#000;position:relative}
.kn-course-img img{width:100%;height:100%;object-fit:cover}
.kn-course-badge{position:absolute;top:14px;left:14px;padding:5px 12px;background:var(--kn-glow);color:var(--kn-bg);font-size:11px;font-weight:700;border-radius:999px;letter-spacing:.05em}
.kn-course-body{padding:24px;flex:1;display:flex;flex-direction:column;gap:12px}
.kn-course-title{font-family:var(--kn-font-serif);font-size:22px;font-weight:700;margin:0;line-height:1.35}
.kn-course-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:12.5px;color:var(--kn-fg-mute)}
.kn-course-meta b{color:var(--kn-fg);font-weight:600;margin-right:4px}
.kn-course-text{color:var(--kn-fg-mute);font-size:14px;line-height:1.85;margin:0;flex:1}
.kn-course-price{display:flex;align-items:baseline;gap:6px;padding-top:10px;border-top:1px dashed var(--kn-line)}
.kn-course-price .num{font-family:var(--kn-font-serif);font-size:26px;font-weight:700;color:var(--kn-glow)}
.kn-course-price .unit{font-size:12px;color:var(--kn-fg-mute)}
.kn-course-cta{margin-top:6px;align-self:flex-start}

.kn-highlights{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:720px){.kn-highlights{grid-template-columns:1fr}}
.kn-highlights li{padding:24px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius)}
.kn-hi-icon{width:42px;height:42px;border-radius:12px;background:rgba(181,228,140,.14);color:var(--kn-glow);display:grid;place-items:center;margin-bottom:14px;font-size:22px}
.kn-hi-title{font-size:15px;font-weight:700;margin:0 0 6px}
.kn-hi-text{font-size:13.5px;color:var(--kn-fg-mute);line-height:1.85;margin:0}

.kn-checklist{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media (max-width:720px){.kn-checklist{grid-template-columns:1fr}}
.kn-checklist li{display:flex;gap:12px;padding:14px 18px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius-sm);font-size:14px;color:var(--kn-fg-mute)}
.kn-checklist .kn-check{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:rgba(181,228,140,.18);color:var(--kn-glow);display:grid;place-items:center;font-size:12px;font-weight:700;margin-top:1px}

/* Booking panel */
.kn-booking{display:grid;grid-template-columns:auto 1fr;gap:36px;align-items:center;padding:32px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius-lg)}
@media (max-width:720px){.kn-booking{grid-template-columns:1fr;text-align:center}}
.kn-booking-qr{width:180px;height:180px;background:#fff;padding:12px;border-radius:var(--kn-radius);justify-self:center}
.kn-booking-qr img{width:100%;height:100%;object-fit:contain}
.kn-booking h3{font-family:var(--kn-font-serif);font-size:24px;font-weight:700;margin:0 0 8px}
.kn-booking p{color:var(--kn-fg-mute);margin:0 0 18px;font-size:14.5px;line-height:1.85}
.kn-booking-btns{display:flex;flex-wrap:wrap;gap:10px}
@media (max-width:720px){.kn-booking-btns{justify-content:center}}

/* Learn page */
.kn-learn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:880px){.kn-learn-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.kn-learn-grid{grid-template-columns:1fr}}
.kn-learn-card{display:flex;flex-direction:column;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius);overflow:hidden;transition:transform .25s,border-color .25s}
.kn-learn-card:hover{transform:translateY(-4px);border-color:rgba(181,228,140,.35)}
.kn-learn-thumb{aspect-ratio:16/10;background:linear-gradient(135deg,rgba(45,106,79,.4),rgba(181,228,140,.15));display:grid;place-items:center;color:var(--kn-glow);font-size:48px;position:relative}
.kn-learn-thumb::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 60%,rgba(181,228,140,.25),transparent 60%);pointer-events:none}
.kn-learn-body{padding:22px;flex:1;display:flex;flex-direction:column;gap:8px}
.kn-learn-tag{font-size:10px;font-family:var(--kn-font-mono);color:var(--kn-glow);letter-spacing:.18em;text-transform:uppercase}
.kn-learn-title{font-family:var(--kn-font-serif);font-size:19px;font-weight:700;margin:0;line-height:1.35}
.kn-learn-text{font-size:13.5px;color:var(--kn-fg-mute);line-height:1.85;margin:0;flex:1}
.kn-learn-more{font-size:13px;font-weight:700;color:var(--kn-glow);margin-top:6px}

.kn-prose h3{font-family:var(--kn-font-serif);font-size:24px;font-weight:700;margin:48px 0 14px;padding-left:16px;border-left:3px solid var(--kn-glow);line-height:1.3}
.kn-prose h3:first-child{margin-top:0}
.kn-prose p{color:var(--kn-fg-mute);margin:0 0 16px;line-height:1.95}
.kn-prose ul{padding-left:1.4em;color:var(--kn-fg-mute);line-height:1.95}
.kn-prose ul li{margin:8px 0}
.kn-prose strong{color:var(--kn-fg);font-weight:600}
.kn-prose a{color:var(--kn-glow);text-decoration:underline;text-underline-offset:3px}

/* Access page */
.kn-access-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:48px}
@media (max-width:720px){.kn-access-grid{grid-template-columns:1fr}}
.kn-access-grid.kn-island{grid-template-columns:repeat(4,1fr)}
@media (max-width:880px){.kn-access-grid.kn-island{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.kn-access-grid.kn-island{grid-template-columns:1fr}}
.kn-access-card{padding:28px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius)}
.kn-access-icon{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,rgba(181,228,140,.2),rgba(45,106,79,.3));color:var(--kn-glow);display:grid;place-items:center;font-size:28px;margin-bottom:16px}
.kn-access-card h3{font-family:var(--kn-font-serif);font-size:19px;font-weight:700;margin:0 0 14px;line-height:1.35}
.kn-access-card p{color:var(--kn-fg-mute);margin:0 0 12px;font-size:14px;line-height:1.85}
.kn-access-card ul{padding-left:1.3em;color:var(--kn-fg-mute);font-size:13.5px;line-height:1.85;margin:0}

.kn-info-table{width:100%;border-collapse:collapse;margin:0 0 16px;font-size:14px}
.kn-info-table th,.kn-info-table td{padding:10px 12px;text-align:left;vertical-align:top;border-bottom:1px solid var(--kn-line)}
.kn-info-table th{color:var(--kn-fg-mute);font-weight:500;font-size:12.5px;width:35%;font-family:var(--kn-font-mono);letter-spacing:.04em}
.kn-info-table td{color:var(--kn-fg)}
.kn-info-box{padding:16px 18px;background:rgba(181,228,140,.06);border:1px solid rgba(181,228,140,.2);border-radius:var(--kn-radius-sm);margin-top:14px}
.kn-info-box strong{display:block;color:var(--kn-glow);font-size:13px;letter-spacing:.05em;margin-bottom:6px}
.kn-info-box p{margin:0;font-size:13.5px;color:var(--kn-fg-mute);line-height:1.85}

/* Highlight (used on home + tour) */
.kn-highlight-bar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:20px}
.kn-highlight-bar a{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:999px;font-size:13px;font-weight:600;color:var(--kn-fg-mute);transition:all .2s}
.kn-highlight-bar a:hover{color:var(--kn-glow);border-color:rgba(181,228,140,.45)}

/* About page-specific */
.kn-section.kn-light{background:var(--kn-bg)}
.kn-card-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
@media (max-width:880px){.kn-card-row{grid-template-columns:1fr}}

.kn-stops{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}
.kn-stops li{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:16px 0;border-top:1px dashed var(--kn-line);align-items:start}
.kn-stops li:first-child{border-top:0}
.kn-stops time{font-family:var(--kn-font-mono);font-size:12px;color:var(--kn-glow);letter-spacing:.05em;padding-top:2px;min-width:60px}
.kn-stops .kn-stop-text{font-size:14px;color:var(--kn-fg);line-height:1.7}
.kn-stops small{display:block;color:var(--kn-fg-mute);font-size:12.5px;margin-top:4px}

/* Mobile nav active state */
.kn-nav-link-m.is-active{color:var(--kn-glow)}

/* Section variants */
.kn-section.kn-section-tight{padding:60px 0}


/* === Learn 2-col text/image layout === */
.kn-learn-grid-2{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center}
.kn-learn-grid-2.kn-rev{grid-template-columns:1fr 1.05fr;direction:rtl}
.kn-learn-grid-2.kn-rev > *{direction:ltr}
@media (max-width:880px){.kn-learn-grid-2,.kn-learn-grid-2.kn-rev{grid-template-columns:1fr;gap:28px;direction:ltr}}
.kn-learn-text .kn-kicker{display:block;margin-bottom:10px}
.kn-learn-text .kn-h3{font-family:var(--kn-font-serif);font-size:clamp(24px,3vw,32px);font-weight:700;line-height:1.35;margin:0 0 18px}
.kn-learn-text .kn-body{color:var(--kn-fg-mute);line-height:2;font-size:14.5px;margin:0 0 14px}
.kn-learn-text .kn-body em{font-style:italic;color:var(--kn-glow)}
.kn-learn-img{margin:0;border-radius:var(--kn-radius-lg);overflow:hidden;border:1px solid var(--kn-line);background:var(--kn-card)}
.kn-learn-img img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.kn-learn-img figcaption{padding:14px 18px;font-size:12px;color:var(--kn-fg-mute);font-family:var(--kn-font-mono);letter-spacing:.04em}

/* === Learn mechanism === */
.kn-mech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}
@media (max-width:880px){.kn-mech-grid{grid-template-columns:1fr}}
.kn-mech-step{position:relative;padding:32px 26px 26px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius)}
.kn-mech-step::before{content:'';position:absolute;top:0;left:0;width:60px;height:3px;background:var(--kn-glow);border-radius:0 0 3px 0;box-shadow:0 0 12px rgba(181,228,140,.5)}
.kn-mech-num{font-family:var(--kn-font-serif);font-size:42px;font-weight:700;color:var(--kn-glow);line-height:1;margin-bottom:14px;opacity:.95}
.kn-mech-step h3{font-family:var(--kn-font-serif);font-size:18px;font-weight:700;margin:0 0 10px}
.kn-mech-step p{font-size:13.5px;color:var(--kn-fg-mute);line-height:1.85;margin:0}

/* === Learn data table === */
.kn-data-table{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--kn-line);margin-top:24px}
@media (max-width:720px){.kn-data-table{grid-template-columns:1fr}}
.kn-data-table > div{display:grid;grid-template-columns:140px 1fr;gap:18px;padding:14px 18px;border-bottom:1px solid var(--kn-line);align-items:baseline}
.kn-data-table > div b{font-family:var(--kn-font-mono);font-size:11.5px;color:var(--kn-fg-mute);letter-spacing:.08em;text-transform:uppercase;font-weight:500}
.kn-data-table > div span{font-size:14px;color:var(--kn-fg);font-style:italic;font-family:var(--kn-font-serif)}

/* h2/h3 helpers */
.kn-h3{font-family:var(--kn-font-serif);font-size:clamp(22px,2.6vw,28px);font-weight:700;line-height:1.35;margin:0 0 18px;letter-spacing:.01em}

/* === Access meeting points === */
.kn-meeting-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:36px}
@media (max-width:880px){.kn-meeting-grid{grid-template-columns:1fr}}
.kn-meeting{padding:26px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius);position:relative;display:block;text-align:left;text-decoration:none;color:inherit;width:100%;font:inherit;cursor:pointer;transition:border-color .25s,transform .25s,background .25s}
.kn-meeting:hover{border-color:var(--kn-glow);background:rgba(181,228,140,.04);transform:translateY(-2px)}
.kn-meeting:hover .kn-meeting-cta{color:var(--kn-glow)}
.kn-meeting:hover .kn-meeting-cta span:last-child{transform:translateY(2px)}
.kn-meeting.is-active{border-color:var(--kn-glow);background:rgba(181,228,140,.06);box-shadow:0 0 0 1px var(--kn-glow) inset,0 0 24px rgba(181,228,140,.12)}
.kn-meeting.is-active .kn-meeting-cta{color:var(--kn-glow)}

/* === Map tabs === */
.kn-map-tabs{display:flex;flex-wrap:wrap;gap:6px;padding:10px 12px;background:rgba(10,18,15,.85);border-bottom:1px solid var(--kn-line)}
.kn-map-tab{flex:1;min-width:0;padding:10px 14px;background:transparent;border:1px solid var(--kn-line);border-radius:8px;color:var(--kn-fg-mute);font:inherit;font-size:12px;letter-spacing:.04em;cursor:pointer;display:flex;align-items:center;gap:8px;justify-content:center;transition:border-color .2s,background .2s,color .2s}
.kn-map-tab:hover{color:var(--kn-fg);border-color:var(--kn-glow)}
.kn-map-tab.is-active{background:rgba(181,228,140,.1);border-color:var(--kn-glow);color:var(--kn-glow)}
.kn-map-tab-num{font-family:var(--kn-font-mono);font-size:10.5px;letter-spacing:.12em;opacity:.85}
@media (max-width:680px){.kn-map-tab{flex:1 1 calc(50% - 6px);font-size:11px;padding:8px 10px}}
.kn-meeting-num{font-family:var(--kn-font-mono);font-size:11px;color:var(--kn-glow);letter-spacing:.18em;margin-bottom:10px}
.kn-meeting h3{font-family:var(--kn-font-serif);font-size:19px;font-weight:700;margin:0 0 6px}
.kn-meeting-tour{font-size:12.5px;color:var(--kn-glow);margin:0 0 18px;font-family:var(--kn-font-mono);letter-spacing:.04em}
.kn-meeting-info{display:flex;flex-direction:column;gap:10px;padding-top:16px;border-top:1px dashed var(--kn-line)}
.kn-meeting-info > div{display:grid;grid-template-columns:50px 1fr;gap:14px;align-items:start}
.kn-meeting-info b{font-family:var(--kn-font-mono);font-size:10.5px;color:var(--kn-fg-mute);letter-spacing:.08em;font-weight:500;padding-top:2px}
.kn-meeting-info span{font-size:13px;color:var(--kn-fg);line-height:1.6}
.kn-meeting-cta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:18px;padding-top:14px;border-top:1px dashed var(--kn-line);font-family:var(--kn-font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--kn-fg-mute);transition:color .25s}
.kn-meeting-cta span:last-child{font-size:14px;display:inline-block;transition:transform .25s}

/* === Map embed (Google Maps) === */
.kn-map-embed{position:relative;width:100%;border:1px solid var(--kn-line);border-radius:var(--kn-radius-lg);overflow:hidden;background:#0e1d17;margin-top:8px}
.kn-map-embed iframe{display:block;width:100%;height:480px;border:0;filter:invert(.92) hue-rotate(180deg) saturate(.85) brightness(.95) contrast(.95)}
@media (max-width:680px){.kn-map-embed iframe{height:360px}}
.kn-map-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:rgba(10,18,15,.85);border-top:1px solid var(--kn-line);font-family:var(--kn-font-mono);font-size:11px;letter-spacing:.08em;color:var(--kn-fg-mute);text-transform:uppercase}
.kn-map-foot a{color:var(--kn-glow);text-decoration:none;border-bottom:1px solid rgba(181,228,140,.3);padding-bottom:1px;transition:border-color .2s}
.kn-map-foot a:hover{border-bottom-color:var(--kn-glow)}

/* === Access on-island === */
.kn-onisland{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:24px}
@media (max-width:880px){.kn-onisland{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.kn-onisland{grid-template-columns:1fr}}
.kn-onisland > div{padding:22px;background:var(--kn-card);border:1px solid var(--kn-line);border-radius:var(--kn-radius)}
.kn-onisland h4{font-family:var(--kn-font-serif);font-size:16px;font-weight:700;margin:0 0 10px}
.kn-onisland p{font-size:13px;color:var(--kn-fg-mute);line-height:1.8;margin:0}

/* Access time-line label */
.kn-access-time{font-family:var(--kn-font-mono);font-size:12px;color:var(--kn-glow);letter-spacing:.04em;margin:0 0 14px}
.kn-access-list{padding-left:1.2em;color:var(--kn-fg-mute);font-size:13.5px;line-height:1.85;margin:0}
.kn-access-list li{margin:4px 0}

/* === Tour: courses (pricing card) extras === */
.kn-course-meta{display:flex;flex-wrap:wrap;gap:6px 12px;margin:12px 0 14px;font-size:12px;color:var(--kn-fg-mute);font-family:var(--kn-font-mono);letter-spacing:.02em}
.kn-course-meta span{display:inline-flex;gap:6px;align-items:baseline}
.kn-course-meta b{color:var(--kn-glow);font-weight:500;letter-spacing:.04em}
.kn-course-meta span:not(:last-child)::after{content:'·';margin-left:8px;color:var(--kn-line-2)}
.kn-course-text{font-size:13.5px;color:var(--kn-fg-mute);line-height:1.85;margin:0 0 16px}
.kn-course-price{display:flex;align-items:baseline;gap:8px;padding:14px 0;border-top:1px solid var(--kn-line);border-bottom:1px solid var(--kn-line);margin-bottom:16px}
.kn-course-price .num{font-family:var(--kn-font-serif);font-size:32px;font-weight:700;color:var(--kn-glow);line-height:1}
.kn-course-price .unit{font-size:12.5px;color:var(--kn-fg-mute);font-family:var(--kn-font-mono)}
.kn-course-badge{position:absolute;top:14px;left:14px;padding:5px 10px;background:rgba(181,228,140,.92);color:#0b1410;font-size:11px;font-weight:700;letter-spacing:.06em;border-radius:999px;font-family:var(--kn-font-mono)}
.kn-course.is-featured{border-color:rgba(181,228,140,.45);box-shadow:0 0 0 1px rgba(181,228,140,.18)}
