/* kidfun.us relaunch — design tokens, hover/focus states, responsive header, article prose.
   Layout/structure lives inline in the Blade templates (ported from the Claude Design handoff);
   this file covers what inline styles cannot: :hover, :focus, media queries, and DB-driven prose. */

:root{
  --ink:#15243B; --bg:#F6F8FC; --line:#E5EAF2;
  --blue:#2766DB; --blue-dark:#1B4DAB; --blue-soft:#EAF1FE;
  --accent:#F1582E; --green:#0F7A53; --green-soft:#E2F4EC; --green-line:#BFE6D4;
  --muted:#5E6E88; --muted2:#6A7588;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:'Hanken Grotesk',system-ui,sans-serif;color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
a{color:inherit;}
img{max-width:100%;display:block;}
::selection{background:#FCDDA0;color:var(--ink);}
/* Visible keyboard focus everywhere (a11y / WCAG 2.4.7). */
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:3px;}
/* Skip link — visually hidden until focused (WCAG 2.4.1). */
.kf-skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--blue);color:#fff;
  padding:10px 16px;border-radius:0 0 10px 0;font-weight:700;font-size:14px;text-decoration:none;}
.kf-skip:focus{left:0;}
@keyframes kf-fadeup{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
@keyframes kf-drawer{from{opacity:0;transform:translateX(28px);}to{opacity:1;transform:translateX(0);}}

.kf-display{font-family:'Bricolage Grotesque',sans-serif;}

/* ---- interactive states (inline styles can't express :hover/:focus) ---- */
.kf-nav:hover{background:var(--blue-soft);color:var(--blue-dark);}
.kf-cta{transition:filter .15s,transform .15s;}
.kf-cta:hover{filter:brightness(1.05);transform:translateY(-1px);}
.kf-ghost:hover{border-color:var(--blue)!important;color:var(--blue)!important;}
.kf-dark-btn:hover{background:var(--blue)!important;}
.kf-light-btn:hover{background:#FCDDA0!important;}
.kf-card{transition:transform .18s,box-shadow .18s;}
.kf-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -18px rgba(21,36,59,0.28);}
.kf-hub{transition:transform .18s;}
.kf-hub:hover{transform:translateY(-3px);}
.kf-tlink{transition:color .15s,gap .15s;}
.kf-tlink:hover{color:var(--blue);}
.kf-seeall:hover{gap:10px;}
.kf-foot a{transition:color .15s;}
.kf-foot a:hover{color:#fff;}
.kf-chiplink:hover{background:#DBE7FC;}
.kf-pagenum:hover{border-color:var(--blue)!important;color:var(--blue)!important;}
.kf-input{transition:border-color .15s,background .15s;}
.kf-input:focus{border-color:var(--blue)!important;background:#fff!important;box-shadow:0 0 0 3px rgba(39,102,219,0.18);}
/* Header search pill shows a focus ring when its (border-less) input is focused. */
.kf-searchpill:focus-within{border-color:var(--blue)!important;box-shadow:0 0 0 3px rgba(39,102,219,0.18);}
.kf-meganav:hover{color:var(--blue)!important;}

/* ---- age filter chips ---- */
.kf-chip{font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;padding:10px 16px;border-radius:999px;
  border:1px solid #D6DEEA;background:#fff;color:#3A4A63;text-decoration:none;display:inline-block;line-height:1.1;
  transition:background .15s,border-color .15s,color .15s,box-shadow .15s;}
.kf-chip:hover{border-color:var(--blue);color:var(--blue);}
.kf-chip[aria-pressed="true"]{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 6px 14px -6px var(--accent);}
.kf-chip[aria-pressed="true"]:hover{color:#fff;}

/* ---- responsive header: swap desktop nav <-> hamburger ---- */
.kf-hamburger{display:none;}
@media (max-width:879px){
  .kf-desktop-nav{display:none!important;}
  .kf-hamburger{display:flex!important;}
}
body.kf-noscroll{overflow:hidden;}

/* ---- FAQ accordion (native <details>, no JS) ---- */
.kf-faq details{border-top:1px solid #EEF1F6;}
.kf-faq details:first-child{border-top:none;}
.kf-faq summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px;cursor:pointer;padding:18px;}
.kf-faq summary::-webkit-details-marker{display:none;}
.kf-faq-mark{flex:none;width:28px;height:28px;border-radius:8px;background:#F0F3F9;display:flex;align-items:center;
  justify-content:center;font-size:20px;font-weight:600;color:var(--blue);line-height:1;}
.kf-faq-mark::before{content:"+";}
.kf-faq details[open] .kf-faq-mark::before{content:"–";}
.kf-faq-a{padding:0 18px 18px;font-size:15.5px;line-height:1.62;color:#48576F;}
.kf-faq-a p{margin:0;}

/* ---- article / page prose (DB-driven body_html) ---- */
.kf-prose{font-size:17px;line-height:1.68;color:#2C3A52;}
.kf-prose>p{margin:0 0 22px;}
/* Lead paragraph: the opening line of an article reads a touch larger/darker. */
.kf-prose>p:first-of-type{font-size:18.5px;line-height:1.62;color:#33425C;}
.kf-prose h2{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:clamp(22px,3vw,28px);
  letter-spacing:-0.02em;margin:38px 0 8px;scroll-margin-top:90px;color:var(--ink);}
.kf-prose h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:20px;margin:28px 0 8px;scroll-margin-top:90px;color:var(--ink);}
.kf-prose a{color:var(--blue-dark);text-decoration:underline;text-underline-offset:2px;}
.kf-prose strong{color:var(--ink);}
.kf-prose ul,.kf-prose ol{margin:0 0 22px;padding-left:22px;}
.kf-prose li{margin:0 0 8px;}
.kf-prose p.kf-meta{font-size:13px;font-weight:600;color:var(--muted2);margin:0 0 12px;}
.kf-prose table{width:100%;border-collapse:collapse;min-width:520px;font-size:14.5px;margin:0 0 26px;}
.kf-prose thead tr{background:var(--bg);}
.kf-prose th{text-align:left;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  color:var(--muted2);padding:12px 16px;}
.kf-prose td{padding:13px 16px;border-top:1px solid #EEF1F6;color:#3A4A63;}
.kf-prose .kf-tablewrap{border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:30px;}
.kf-prose .kf-callout{display:flex;gap:14px;background:var(--green-soft);border:1px solid var(--green-line);
  border-radius:14px;padding:18px 20px;margin:8px 0 30px;}
.kf-prose .kf-callout span{font-size:22px;line-height:1.2;flex:none;}
.kf-prose .kf-callout p{margin:0;font-size:15.5px;line-height:1.6;color:#1A4A38;}
.kf-prose .kf-callout strong{color:var(--green);}
.kf-prose .kf-warn{background:#FFF6E2;border:1px solid #F6DFA3;border-radius:14px;padding:16px 20px;margin:0 0 22px;}
.kf-prose .kf-warn p{margin:0;font-size:15.5px;line-height:1.6;color:#7A5A12;}

/* ---- imported WordPress / WPBakery body (rendered as-is) ---- */
.kf-prose img{max-width:100%;height:auto;border-radius:14px;}
.kf-prose figure{margin:0 0 22px;}
.kf-prose iframe{max-width:100%;border:0;border-radius:14px;margin:0 0 22px;}
/* Neutralise WPBakery grid wrappers (their own grid CSS isn't loaded) so content single-columns cleanly. */
.kf-prose .vc_row,.kf-prose .wpb_row,.kf-prose .wpb_column,.kf-prose .vc_column_container,
.kf-prose .vc_column-inner,.kf-prose .wpb_wrapper,.kf-prose .wpb_text_column,
.kf-prose .wpb_single_image,.kf-prose .vc_figure,.kf-prose .vc_single_image-wrapper{
  display:block;width:auto!important;max-width:100%;float:none!important;padding:0;margin-left:0;margin-right:0;}
.kf-prose .wpb_single_image,.kf-prose .sp-section{margin-bottom:22px;}
.kf-prose .vc_btn3,.kf-prose .vc_general{display:inline-block;}
