/* =========================================================
   KARKY.IN — Shared Design System
   ========================================================= */
:root{
  /* KILIKI tribal theme — black · white · mask-red.
     The accent variables keep the name --gold (used across the shared system)
     but now resolve to the logo red, so the whole site recolours at once. */
  --kiliki-red:#c32729;
  --kiliki-red-dark:#9e1f21;
  --gold:#c32729;        /* primary accent (was gold) -> mask red */
  --gold-soft:#e0524f;   /* lighter red for dark backgrounds / soft accents */
  --ink:#1f1f1f;
  --ink-deep:#141414;    /* near-black bands */
  --paper:#f6f5f3;       /* clean off-white */
  --paper-warm:#f3edec;  /* faint warm/red-tinted section tone */
  --grey:#777;
  --line:#e6e2de;
  --serif:"Playfair Display",serif;
  --sans:"Poppins",sans-serif;
  --tamil:"Catamaran","Noto Sans Tamil",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.7;font-weight:300;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#fff}
:lang(ta), .ta{font-family:var(--tamil)}

/* ---------- Nav (shared across site) ---------- */
nav.site-nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 4vw;transition:background .4s ease, box-shadow .4s ease, padding .4s ease}
nav.site-nav.scrolled{background:rgba(245,245,245,.92);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line);padding:.7rem 4vw}
.brand{font-family:var(--serif);font-size:1.35rem;font-weight:700;letter-spacing:.5px;display:flex;align-items:baseline;gap:.55rem}
.brand img{height:34px;width:auto}
.brand span{color:var(--gold)}
.brand .bm-desk{font-family:var(--sans);font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:500}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400;position:relative;padding:.2rem 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1.5px;background:var(--gold);transition:width .35s ease}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--gold)}
.nav-links li.desk-link{padding-left:2rem;border-left:1px solid var(--line)}
.nav-links li.desk-link a{color:var(--muted,#8a8a8a);display:inline-flex;align-items:center;gap:.45rem}
.nav-links li.desk-link a:hover{color:var(--gold)}
.nav-extra{display:flex;align-items:center;gap:1rem}
.lang-toggle{font-size:.72rem;letter-spacing:.1em;border:1px solid var(--line);background:#fff;padding:.4rem .85rem;border-radius:100px;cursor:pointer;transition:all .25s ease}
.lang-toggle:hover{border-color:var(--gold);color:var(--gold)}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:.4rem}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink)}
@media(max-width:860px){
  .nav-links{position:fixed;top:0;right:-100%;width:78%;max-width:340px;height:100vh;background:var(--ink-deep);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:1.8rem;padding:2rem 3rem;transition:right .45s cubic-bezier(.2,.7,.2,1)}
  .nav-links.open{right:0}
  .nav-links a{color:#eee;font-size:.9rem}
  .nav-links li.desk-link{padding-left:0;border-left:none;border-top:1px solid rgba(255,255,255,.15);padding-top:1.8rem;width:100%}
  .nav-toggle{display:flex}
  .lang-toggle{color:#eee;border-color:#555}
}

/* ---------- Generic page hero (sub-pages) ---------- */
.page-hero{min-height:46vh;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;
  padding:9rem 6vw 3rem;background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%);position:relative}
.page-hero .kicker{font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;font-weight:500}
.page-hero h1{font-family:var(--serif);font-size:clamp(2.4rem,6vw,4.4rem);font-weight:600;line-height:1.12;color:var(--ink-deep)}
.page-hero h1 em{font-style:italic;color:var(--gold)}
.page-hero p{margin-top:1.2rem;max-width:42rem;color:#5a5a5a;font-size:1.02rem}
.crumb{margin-top:1.6rem;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grey)}
.crumb a{color:var(--gold)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
  padding:.95rem 1.9rem;border:1px solid var(--ink);transition:all .35s ease;cursor:pointer;background:none}
.btn:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn.gold{border-color:var(--gold);background:var(--gold);color:#fff}
.btn.gold:hover{background:var(--kiliki-red-dark);border-color:var(--kiliki-red-dark)}
.btn svg{width:14px;height:14px}

/* ---------- Sections ---------- */
section.block{padding:7rem 6vw}
.sec-head{max-width:640px;margin-bottom:4rem}
.sec-num{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1rem;letter-spacing:.1em}
.sec-head h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:600;line-height:1.15;margin:.5rem 0 1rem}
.sec-head p.lede{color:#5a5a5a;font-size:1.02rem}
.rule{width:64px;height:2px;background:var(--gold);margin-top:1.4rem}

/* ---------- Gateway cards (Home) ---------- */
.gateway{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem;padding:0 6vw 7rem}
.gate-card{position:relative;background:#fff;border:1px solid var(--line);padding:2.2rem 1.9rem;overflow:hidden;
  transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s ease,border-color .4s ease;min-height:220px;
  display:flex;flex-direction:column;justify-content:space-between}
.gate-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-soft) 100%);
  opacity:0;transition:opacity .4s ease;z-index:0}
.gate-card:hover{transform:translateY(-8px);box-shadow:0 24px 50px -24px rgba(40,40,40,.35);border-color:var(--gold-soft)}
.gate-card:hover::before{opacity:.06}
.gate-card .tag{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:500;position:relative;z-index:1}
.gate-card h3{font-family:var(--serif);font-size:1.6rem;font-weight:600;margin:.6rem 0;position:relative;z-index:1}
.gate-card p{font-size:.9rem;color:#5a5a5a;position:relative;z-index:1}
.gate-card .go{margin-top:1.4rem;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;display:flex;align-items:center;gap:.5rem;
  color:var(--ink);position:relative;z-index:1;transition:gap .3s ease,color .3s ease}
.gate-card:hover .go{gap:.9rem;color:var(--gold)}
.gate-card .go svg{width:14px;height:14px;transition:transform .3s ease}
.gate-card:hover .go svg{transform:translateX(4px)}
.gate-card.soon{opacity:.55;cursor:default}
.gate-card.soon:hover{transform:none;box-shadow:none;border-color:var(--line)}
.gate-card.soon::after{content:"Coming Soon";position:absolute;top:1.4rem;right:1.4rem;font-size:.62rem;letter-spacing:.2em;
  text-transform:uppercase;background:var(--paper-warm);border:1px solid var(--line);padding:.3rem .7rem;border-radius:100px;color:var(--grey)}
.gate-card.big{grid-column:span 2}
@media(max-width:640px){.gate-card.big{grid-column:span 1}}

/* ---------- Tool chip strip ---------- */
.toolstrip{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;padding:0 6vw 7rem}
@media(max-width:900px){.toolstrip{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.toolstrip{grid-template-columns:repeat(2,1fr)}}
.tool-pill{background:#fff;border:1px solid var(--line);padding:1.4rem 1.2rem;text-align:center;transition:all .3s ease;
  display:flex;flex-direction:column;align-items:center;gap:.5rem}
.tool-pill:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:0 14px 34px -18px rgba(40,40,40,.25)}
.tool-pill .ic{width:44px;height:44px;border-radius:50%;background:var(--paper-warm);display:flex;align-items:center;justify-content:center;color:var(--gold)}
.tool-pill .ic svg{width:20px;height:20px;stroke:var(--gold);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.tool-pill h5{font-family:var(--serif);font-size:1rem;font-weight:600}
.tool-pill span{font-size:.74rem;color:var(--grey)}

/* ---------- Cards / lists ---------- */
.cardlist{display:grid;gap:1.1rem}
.card{background:#fff;border:1px solid var(--line);padding:1.6rem 1.8rem;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 34px -18px rgba(40,40,40,.25);border-color:var(--gold-soft)}
.card h4{font-family:var(--serif);font-size:1.15rem;font-weight:600}
.card .meta{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.35rem;font-weight:500}
.card p{font-size:.92rem;color:#5a5a5a;margin-top:.4rem}

.chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.4rem}
.chip{font-size:.78rem;padding:.42rem 1rem;border:1px solid var(--line);background:#fff;border-radius:100px;color:#555;
  transition:all .3s ease;cursor:default}
.chip:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.chip b{font-weight:500;color:var(--ink)}
.chip.active{background:var(--gold);color:#fff;border-color:var(--gold)}
.chip[role="button"]{cursor:pointer}

/* ---------- Stats band ---------- */
.stats{background:var(--ink-deep);color:var(--paper);padding:4.2rem 6vw;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:2.5rem;text-align:center}
.stat .num{font-family:var(--serif);font-size:clamp(2rem,3.6vw,3rem);color:var(--gold-soft);font-weight:600}
.stat .num sup{font-size:.5em;color:var(--gold)}
.stat .lbl{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:#9a9a9a;margin-top:.4rem}

/* ---------- Split layouts ---------- */
.split{display:grid;grid-template-columns:5fr 7fr;gap:5vw;align-items:start}
.split.flip{grid-template-columns:7fr 5fr}
@media(max-width:900px){.split,.split.flip{grid-template-columns:1fr}}
.fig{position:relative}
.fig img{filter:saturate(.95)}
.fig figcaption{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--grey);margin-top:.8rem}
.fig.bordered::after{content:"";position:absolute;inset:14px -14px -14px 14px;border:1.5px solid var(--line);z-index:-1}
.sticky{position:sticky;top:90px}
@media(max-width:900px){.sticky{position:static}}

.dl-box{margin-top:2.6rem;background:var(--paper-warm);border:1px solid var(--line);border-left:3px solid var(--gold);
  padding:1.5rem 1.8rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.dl-box .t{font-family:var(--serif);font-weight:600;font-size:1.05rem}
.dl-box .s{font-size:.8rem;color:var(--grey)}

/* ---------- Timeline ---------- */
.timeline{margin-top:.5rem;border-left:1.5px solid var(--line);padding-left:1.8rem;display:grid;gap:1.5rem}
.tl{position:relative}
.tl::before{content:"";position:absolute;left:calc(-1.8rem - 5px);top:.5rem;width:9px;height:9px;border-radius:50%;
  background:var(--paper);border:2px solid var(--gold);transition:background .3s ease}
.tl:hover::before{background:var(--gold)}
.tl .when{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:500}
.tl h4{font-family:var(--serif);font-size:1.08rem;font-weight:600;margin:.15rem 0}
.tl p{font-size:.9rem;color:#5a5a5a}

/* ---------- Quote band ---------- */
.quote-band{position:relative;background:var(--ink-deep);color:var(--paper);overflow:hidden}
.quote-inner{display:grid;grid-template-columns:1fr 1fr;align-items:center;min-height:480px}
.quote-inner .qimg{height:100%;min-height:480px;background-size:cover;background-position:center 25%;filter:grayscale(1) contrast(1.05)}
.quote-inner blockquote{padding:5rem 6vw}
.quote-inner blockquote p{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.5;color:#eee}
.quote-inner blockquote footer{margin-top:1.5rem;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-soft)}
@media(max-width:820px){
  .quote-inner{grid-template-columns:3fr 2fr;min-height:320px}
  .quote-inner .qimg{min-height:320px;order:2;background-position:center top}
  .quote-inner blockquote{order:1;padding:2.5rem 3vw 2.5rem 5vw}
  .quote-inner blockquote p{font-size:clamp(.95rem,3.6vw,1.35rem)}
}

/* ---------- Milestones ---------- */
.milestones{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.1rem;margin-top:2.4rem}
.mile{background:#fff;border:1px solid var(--line);padding:1.7rem;text-align:center;transition:all .35s ease}
.mile:hover{border-color:var(--gold);transform:translateY(-4px)}
.mile .y{font-family:var(--serif);font-size:1.7rem;color:var(--gold);font-weight:600}
.mile .w{font-size:.86rem;color:#555;margin-top:.4rem}

/* ---------- FAQ accordion ---------- */
.faq-search{max-width:520px;margin:0 0 3rem;position:relative}
.faq-search input{width:100%;padding:1rem 1.4rem;border:1px solid var(--line);background:#fff;font-family:var(--sans);font-size:.92rem;
  transition:border-color .3s ease}
.faq-search input:focus{outline:none;border-color:var(--gold)}
.faq-cats{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:3rem}
.faq-group{margin-bottom:3.2rem}
.faq-group > h3{font-family:var(--serif);font-size:1.4rem;font-weight:600;margin-bottom:1rem;color:var(--ink-deep)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.3rem 0;cursor:pointer;
  font-family:var(--serif);font-size:1.05rem;font-weight:600}
.faq-q .plus{font-size:1.4rem;color:var(--gold);transition:transform .35s ease;flex-shrink:0}
.faq-item.open .faq-q .plus{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p, .faq-a div{padding:0 0 1.4rem;color:#5a5a5a;font-size:.95rem;white-space:pre-line}
.faq-item.hidden{display:none}

/* ---------- Lyrics portal ---------- */
.lyric-search{display:flex;gap:.8rem;max-width:560px;margin-top:1.6rem;flex-wrap:wrap}
.lyric-search input{flex:1;min-width:200px;padding:1rem 1.4rem;border:1px solid var(--line);background:#fff;font-family:var(--sans);font-size:.92rem}
.lyric-search input:focus{outline:none;border-color:var(--gold)}
.lyric-tabs{display:flex;flex-wrap:wrap;gap:.6rem;padding:2rem 6vw 0;margin-bottom:2rem;position:relative;z-index:5}
.lyric-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.7rem;padding:0 6vw 5rem}

/* Search results — multi-section layout */
.lyric-search-results{padding:0 6vw 5rem}
.search-section{margin-bottom:3rem}
.search-section-head{display:flex;align-items:center;gap:.8rem;margin-bottom:1.2rem;padding-bottom:.6rem;border-bottom:1px solid var(--line)}
.search-section-label{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;font-weight:500;color:var(--ink-deep)}
.search-section-count{font-size:.72rem;background:var(--gold);color:#fff;border-radius:100px;padding:.18rem .65rem;font-weight:500;font-family:var(--sans)}
.search-sub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.7rem;padding:0}
.lyric-card{position:relative;overflow:hidden;border-radius:4px;cursor:pointer;display:block;text-decoration:none;transition:transform .35s ease,box-shadow .35s ease}
.lyric-card:hover{transform:translateY(-5px);box-shadow:0 18px 40px -16px rgba(20,20,20,.45)}
.lyric-thumb{aspect-ratio:1/1;position:relative;overflow:hidden;background:var(--ink-deep)}
.lyric-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.lyric-card:hover .lyric-thumb img{transform:scale(1.06)}
.lyric-thumb.no-img::after{content:"♪";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2.4rem;color:rgba(255,255,255,.15)}
.lyric-caption{position:absolute;bottom:0;left:0;right:0;padding:2.5rem .8rem .7rem;background:linear-gradient(to top,rgba(10,10,10,.92) 0%,rgba(10,10,10,.4) 65%,transparent 100%);transition:padding .3s ease}
.lyric-card:hover .lyric-caption{padding-bottom:.9rem}
.lyric-caption .song{font-family:var(--tamil),var(--serif);font-size:.92rem;font-weight:700;color:#fff;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.lyric-caption .movie{font-family:var(--tamil),var(--serif);font-size:.72rem;color:var(--gold-soft);margin-top:.22rem;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.loading-row{padding:2rem 6vw;color:var(--grey);font-size:.9rem;letter-spacing:.1em;text-transform:uppercase}
.lyric-detail{padding:9rem 6vw 5rem;max-width:960px;margin:0 auto}
/* --- Song detail hero --- */
.song-hero{display:grid;grid-template-columns:220px 1fr;gap:2.5rem;align-items:start;margin-bottom:2.5rem}
.song-art-col{display:flex;flex-direction:column;gap:.7rem}
.song-art{aspect-ratio:1/1;overflow:hidden;background:var(--ink-deep);border-radius:6px;position:relative}
.song-art img{width:100%;height:100%;object-fit:cover;display:block}
.song-art.no-img::after{content:"♪";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:3rem;color:rgba(255,255,255,.18)}
.song-rating{display:flex;gap:.18rem;justify-content:center;padding:.1rem 0}
.song-rating .star{font-size:1.15rem;color:var(--gold);line-height:1}
.song-rating .star.empty{color:var(--line)}
.song-info{display:flex;flex-direction:column}
.song-info h1{font-family:var(--tamil),var(--serif);font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:700;line-height:1.25;margin-bottom:1.2rem;color:var(--ink-deep)}
.song-meta-grid{display:flex;flex-direction:column;gap:.35rem}
.meta-row{display:grid;grid-template-columns:80px 1fr;gap:.6rem;align-items:baseline}
.meta-lbl{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--grey);padding-top:.1rem}
.meta-val{font-family:var(--tamil),var(--sans);font-size:.9rem;color:var(--ink);font-weight:500;line-height:1.4}
@media(max-width:640px){.song-hero{grid-template-columns:1fr}.song-art{max-width:160px}}
.lyric-text{font-family:var(--tamil),var(--serif);font-size:1.15rem;line-height:2;white-space:pre-line;color:var(--ink-deep)}
.lyric-text.translation{font-family:var(--sans);font-style:italic;color:#5a5a5a;font-size:.98rem;margin-top:2.5rem;border-top:1px solid var(--line);padding-top:2rem}
.lyric-table{border-collapse:collapse;width:100%}
.lyric-table tr td{padding:0;vertical-align:top;line-height:2}
.lyric-table tr td:first-child{width:7%;color:var(--gold);font-weight:600;padding-right:.6rem}
.lyric-table tr td[colspan]{height:1.4rem;line-height:1.4rem;padding:0}
.spotify-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.6rem}
.spotify-embed iframe{display:block;width:100%}
.spotify-label{font-family:var(--sans);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}
.spotify-embed--artist{grid-column:1/-1}

/* ---------- Filmography ---------- */
.filter-bar{display:flex;flex-wrap:wrap;gap:.6rem;padding:0 6vw 2.5rem;align-items:center}
.filmo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.2rem;padding:0 6vw 6rem}
.filmo-card{background:#fff;border:1px solid var(--line);padding:1.6rem 1.8rem;transition:all .35s ease}
.filmo-card:hover{transform:translateY(-4px);box-shadow:0 14px 34px -18px rgba(40,40,40,.25);border-color:var(--gold-soft)}
.filmo-card .yr{font-family:var(--serif);color:var(--gold);font-size:.85rem;letter-spacing:.1em;font-weight:500}
.filmo-card h4{font-family:var(--serif);font-size:1.25rem;font-weight:600;margin:.3rem 0 .5rem}
.filmo-card .roles2{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:#999;margin-bottom:.6rem}
.filmo-card p{font-size:.88rem;color:#5a5a5a}
.filmo-card.hidden{display:none}

/* ---------- Generic card grid ---------- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem}
.info-card{display:block;background:#fff;border:1px solid var(--line);padding:1.8rem;transition:all .35s ease}
.info-card:hover{transform:translateY(-4px);box-shadow:0 14px 34px -18px rgba(40,40,40,.25);border-color:var(--gold-soft)}
.info-card h4{font-family:var(--serif);font-size:1.15rem;font-weight:600;margin-bottom:.5rem;color:var(--ink-deep)}
.info-card p{font-size:.88rem;color:#5a5a5a}

/* ---------- Footer ---------- */
footer.site-footer{background:var(--ink-deep);color:#9a9a9a;padding:4.5rem 6vw 2.5rem}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;max-width:1280px}
footer h5{font-family:var(--serif);color:var(--paper);font-size:1.2rem;margin-bottom:1rem}
footer a{font-size:.88rem;display:block;margin:.45rem 0;transition:color .3s}
footer a:hover{color:var(--gold-soft)}
footer p{font-size:.88rem}
.social-links{display:flex;gap:.65rem;margin-top:1.1rem}
.social-links a{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:1px solid #3a3a3a;color:#9a9a9a;transition:color .25s,border-color .25s;margin:0}
.social-links a:hover{color:var(--gold-soft);border-color:var(--gold-soft)}
.social-links a svg{width:15px;height:15px;flex-shrink:0}
.copy{margin-top:3.5rem;padding-top:1.5rem;border-top:1px solid #3a3a3a;font-size:.74rem;letter-spacing:.08em;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.foot-grid{grid-template-columns:1fr}}

/* ---------- Reveal-on-scroll ---------- */
body.js .reveal{opacity:0;transform:translateY(34px);transition:opacity .9s cubic-bezier(.2,.65,.3,1),transform .9s cubic-bezier(.2,.65,.3,1)}
body.js .reveal.visible{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}.reveal.d3{transition-delay:.36s}
@media(prefers-reduced-motion:reduce){
  body.js .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- Preloader ---------- */
#preloader{position:fixed;inset:0;background:var(--paper);z-index:9999;display:flex;align-items:center;justify-content:center;
  transition:opacity .6s ease, visibility .6s ease}
#preloader.done{opacity:0;visibility:hidden}
#preloader .mark{font-family:var(--serif);font-size:1.6rem;letter-spacing:.3em;color:var(--ink-deep);position:relative}
#preloader .mark::after{content:"";position:absolute;left:0;bottom:-8px;height:2px;width:100%;background:var(--gold);
  transform:scaleX(0);transform-origin:left;animation:loadbar 1.1s ease forwards}
@keyframes loadbar{to{transform:scaleX(1)}}

/* =========================================================
   KILIKI — script font + learn/tool additions
   ========================================================= */
@font-face{
  font-family:"Kiliki";
  src:url("../fonts/kiliki.woff") format("woff"),
      url("../fonts/kiliki.ttf") format("truetype"),
      url("../fonts/kiliki.otf") format("opentype");
  font-display:swap;
}
.kiliki-font,.kf{font-family:"Kiliki",sans-serif}
/* Enable ALL Kiliki ligatures (liga + dlig) wherever the script font renders.
   The "i on top of k" stacking in words like kiliki is a discretionary ligature (dlig),
   which browsers keep off by default — so it must be turned on explicitly. */
.kiliki-font,.kf,.km,.kiliki-script-hero,.g-char,.nc-k,.nd-k,.nd-rom,.fc-k,.soon-k,.bc-mark,.as-k,.hero-glyph,[style*="Kiliki"],[style*="kiliki"]{
  -webkit-font-feature-settings:"liga" 1,"dlig" 1,"clig" 1,"calt" 1;
  font-feature-settings:"liga" 1,"dlig" 1,"clig" 1,"calt" 1;
  font-variant-ligatures:common-ligatures discretionary-ligatures contextual;
}

/* Brand mark for Kiliki nav */
.brand .km{font-family:"Kiliki",sans-serif;font-size:1.5rem;color:var(--gold);line-height:1}

/* Hero kiliki sample */
.kiliki-script-hero{font-family:"Kiliki",sans-serif;color:var(--gold);line-height:1.1;letter-spacing:.04em}

/* ---------- Learn page: section blocks ---------- */
.learn-block{margin-bottom:3.5rem}
.learn-block .lb-head{display:flex;align-items:baseline;gap:1rem;margin-bottom:1.4rem;flex-wrap:wrap}
.learn-block .lb-head h3{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--ink-deep)}
.learn-block .lb-head .lb-sub{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--grey)}

/* Pill tab switch (Short/Long etc.) */
.kt-tabs{display:inline-flex;gap:.4rem;background:var(--paper-warm);border:1px solid var(--line);border-radius:100px;padding:.3rem;margin-bottom:1.4rem}
.kt-tab{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;padding:.5rem 1.2rem;border-radius:100px;cursor:pointer;color:#666;transition:all .3s ease}
.kt-tab.active{background:var(--gold);color:#fff}
.kt-panel{display:none}
.kt-panel.active{display:block}

/* Alphabet / glyph grid */
.glyph-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:.9rem}
.glyph{position:relative;background:#fff;border:1px solid var(--line);border-radius:6px;padding:1.4rem 1rem 1rem;text-align:center;
  transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}
.glyph:hover{transform:translateY(-4px);box-shadow:0 14px 30px -18px rgba(40,40,40,.3);border-color:var(--gold-soft)}
.glyph .g-char{font-family:"Kiliki",sans-serif;font-size:2.6rem;line-height:1;color:var(--ink-deep);display:block;margin-bottom:.5rem}
.glyph .g-rom{font-size:.86rem;letter-spacing:.05em;color:var(--gold);font-weight:500}
.glyph .g-audio{position:absolute;top:.55rem;right:.55rem;width:26px;height:26px;border-radius:50%;border:1px solid var(--line);
  background:var(--paper-warm);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gold);transition:all .25s ease}
.glyph .g-audio:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
.glyph .g-audio svg{width:12px;height:12px}
.glyph.playing{border-color:var(--gold)}
.glyph.playing .g-audio{background:var(--gold);color:#fff}

/* ---------- Numbers: tab strip + detail ---------- */
.num-strip{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}
.num-chip{display:flex;flex-direction:column;align-items:center;gap:.2rem;min-width:60px;padding:.7rem .6rem;background:#fff;border:1px solid var(--line);
  border-radius:6px;cursor:pointer;transition:all .3s ease}
.num-chip:hover{border-color:var(--gold-soft);transform:translateY(-2px)}
.num-chip.active{background:var(--ink-deep);border-color:var(--ink-deep)}
.num-chip .nc-k{font-family:"Kiliki",sans-serif;font-size:1.5rem;line-height:1;color:var(--ink-deep)}
.num-chip.active .nc-k{color:var(--gold-soft)}
.num-chip .nc-n{font-size:.74rem;color:var(--grey);font-weight:500}
.num-chip.active .nc-n{color:#bbb}
.num-detail{background:#fff;border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:6px;padding:2.6rem 2rem;text-align:center}
.num-detail .nd-k{font-family:"Kiliki",sans-serif;font-size:5rem;line-height:1;color:var(--ink-deep)}
.num-detail .nd-rom{font-family:"Kiliki",sans-serif;font-size:1.6rem;color:var(--gold);margin-top:.4rem}
.num-detail .nd-rom .rom-en{font-family:var(--sans);font-size:.9rem;color:var(--grey);margin-left:.6rem;letter-spacing:.05em}
.num-detail h4{font-family:var(--serif);font-size:1.2rem;font-weight:600;margin:1.2rem 0 .3rem}
.num-detail p{color:#5a5a5a;font-size:.95rem}
.num-detail .nd-audio{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.2rem;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  border:1px solid var(--line);background:var(--paper-warm);color:var(--gold);padding:.55rem 1.2rem;border-radius:100px;cursor:pointer;transition:all .25s ease;font-weight:500}
.num-detail .nd-audio:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
.num-detail .nd-audio svg{width:14px;height:14px}

/* ---------- Two-column learn layout ---------- */
.learn-wrap{display:grid;grid-template-columns:1fr;gap:0;padding:5rem 6vw 6rem;max-width:1080px;margin:0 auto}

/* ---------- Coming soon block ---------- */
.soon-block{padding:7rem 6vw;text-align:center}
.soon-block .soon-k{font-family:"Kiliki",sans-serif;font-size:4rem;color:var(--gold-soft);margin-bottom:1rem}
.soon-block h2{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:600;color:var(--ink-deep)}
.soon-block p{color:#5a5a5a;margin-top:1rem;max-width:34rem;margin-left:auto;margin-right:auto}

/* ---------- Download font box ---------- */
.font-cta{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;background:var(--paper-warm);
  border:1px solid var(--line);border-left:3px solid var(--gold);padding:1.6rem 1.8rem;margin-top:2.5rem}
.font-cta .fc-k{font-family:"Kiliki",sans-serif;font-size:2rem;color:var(--gold)}
.font-cta .fc-t{font-family:var(--serif);font-weight:600;font-size:1.05rem}
.font-cta .fc-s{font-size:.82rem;color:var(--grey)}

/* ---------- Media / video grid ---------- */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.4rem}
.media-card{background:#fff;border:1px solid var(--line);border-radius:6px;overflow:hidden;transition:all .35s ease;cursor:pointer;display:block}
.media-card:hover{transform:translateY(-5px);box-shadow:0 18px 40px -18px rgba(20,20,20,.3);border-color:var(--gold-soft)}
.media-thumb{aspect-ratio:16/9;background:var(--ink-deep);position:relative;overflow:hidden}
.media-thumb img{width:100%;height:100%;object-fit:cover}
.media-thumb .play-ic{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.media-thumb .play-ic span{width:54px;height:54px;border-radius:50%;background:rgba(189,131,72,.92);display:flex;align-items:center;justify-content:center;transition:transform .3s ease}
.media-card:hover .play-ic span{transform:scale(1.1)}
.media-thumb .play-ic svg{width:20px;height:20px;fill:#fff;margin-left:3px}
.media-body{padding:1.1rem 1.3rem}
.media-body h4{font-family:var(--serif);font-size:1.05rem;font-weight:600;color:var(--ink-deep);line-height:1.35}
.media-body .m-meta{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:.4rem}

/* Empty / loading state for API sections */
.api-state{border:1px dashed var(--line);border-radius:8px;padding:3rem 2rem;text-align:center;color:var(--grey);background:#fff}
.api-state .as-k{font-family:"Kiliki",sans-serif;font-size:2.4rem;color:var(--gold-soft);margin-bottom:.6rem}
.api-state p{font-size:.92rem;max-width:30rem;margin:0 auto}

/* ---------- Blog list ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.6rem}
.blog-card{background:#fff;border:1px solid var(--line);border-radius:6px;overflow:hidden;transition:all .35s ease;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-5px);box-shadow:0 18px 40px -18px rgba(20,20,20,.28);border-color:var(--gold-soft)}
.blog-card .bc-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,var(--ink-deep),#3a3027);position:relative;overflow:hidden}
.blog-card .bc-thumb img{width:100%;height:100%;object-fit:cover}
.blog-card .bc-thumb .bc-mark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:"Kiliki",sans-serif;font-size:2.6rem;color:rgba(198,156,109,.4)}
.blog-card .bc-body{padding:1.2rem 1.3rem 1.3rem;flex:1;display:flex;flex-direction:column}
.blog-card .bc-date{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:500}
.blog-card h3{font-family:var(--serif);font-size:1.1rem;font-weight:600;margin:.4rem 0 .35rem;color:var(--ink-deep);line-height:1.3}
.blog-card p{font-size:.84rem;color:#5a5a5a;flex:1;line-height:1.55}
.blog-card .bc-go{margin-top:.9rem;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:.45rem;transition:gap .3s,color .3s}
.blog-card .bc-go svg{width:13px;height:13px;flex-shrink:0}
.blog-card:hover .bc-go{gap:.75rem;color:var(--gold)}

/* Blog article rich content (from WordPress) */
.a-body figure{margin:2rem 0;text-align:center}
.a-body figure img{margin:0 auto;border-radius:6px}
.a-body img{max-width:100%;height:auto;border-radius:6px}
.a-body figcaption{font-size:.82rem;color:var(--grey);margin-top:.6rem;font-style:italic}
.a-body ul,.a-body ol{margin:0 0 1.4rem 1.4rem}
.a-body li{margin:.4rem 0;line-height:1.7}
.a-body h3{font-family:var(--serif);font-size:1.25rem;margin:1.8rem 0 .8rem;color:var(--ink-deep)}
.a-body blockquote{margin:1.8rem 0;padding:1rem 1.6rem;border-left:3px solid var(--gold);background:var(--paper-warm);
  font-style:italic;color:#444}
.a-body blockquote p:last-child{margin-bottom:0}
.a-body table{border-collapse:collapse;width:100%;margin:1.6rem 0;font-size:.95rem}
.a-body table td,.a-body table th{border:1px solid var(--line);padding:.6rem .8rem;text-align:left}
.a-body table th{background:var(--paper-warm)}
.a-body a{color:var(--kiliki-red);text-decoration:underline;text-underline-offset:2px}
.a-body .wp-block-image{margin:2rem 0}

/* Blog article */
.article{max-width:760px;margin:0 auto;padding:8rem 6vw 5rem}
.article .a-meta{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:1rem}
.article h1{font-family:var(--serif);font-size:clamp(1.9rem,4vw,2.8rem);font-weight:600;line-height:1.2;color:var(--ink-deep)}
.article .a-body{margin-top:2.4rem;font-size:1.05rem;line-height:1.85;color:#3f3f3f}
.article .a-body p{margin-bottom:1.4rem}
.article .a-body h2{font-family:var(--serif);font-size:1.5rem;margin:2.2rem 0 1rem;color:var(--ink-deep)}
.article .a-body img{border-radius:6px;margin:1.6rem 0}

/* Simple contact form */
.kform{display:grid;gap:1.1rem;max-width:560px}
.kform .row2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:560px){.kform .row2{grid-template-columns:1fr}}
.kform label{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grey);display:block;margin-bottom:.4rem;font-weight:500}
.kform input,.kform textarea{width:100%;padding:.9rem 1.1rem;border:1px solid var(--line);background:#fff;font-family:var(--sans);font-size:.92rem;color:var(--ink);transition:border-color .3s ease}
.kform input:focus,.kform textarea:focus{outline:none;border-color:var(--gold)}
.kform textarea{min-height:140px;resize:vertical}

/* Team grid */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.6rem}
.team-card{background:#fff;border:1px solid var(--line);border-radius:6px;padding:2rem 1.5rem;text-align:center;transition:all .35s ease}
.team-card:hover{transform:translateY(-5px);box-shadow:0 18px 40px -18px rgba(20,20,20,.25);border-color:var(--gold-soft)}
.team-card .t-avatar{width:96px;height:96px;border-radius:50%;margin:0 auto 1.1rem;background:var(--paper-warm);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:2rem;color:var(--gold);overflow:hidden}
.team-card .t-avatar img{width:100%;height:100%;object-fit:cover}
.team-card h4{font-family:var(--serif);font-size:1.15rem;font-weight:600;color:var(--ink-deep)}
.team-card .t-role{font-size:.78rem;letter-spacing:.1em;color:var(--gold);margin-top:.3rem}

/* ---------- Dictionary ---------- */
.dict-panel{max-width:720px;margin:0 auto;text-align:center}
.dict-panel .dict-search{justify-content:center}
.dict-panel .dict-hint{text-align:center}
.dict-panel .dict-result{text-align:left}
.dict-toggle{display:inline-flex;gap:.3rem;background:var(--paper-warm);border:1px solid var(--line);border-radius:100px;padding:.3rem;margin-bottom:1.1rem}
.dict-toggle button{border:none;background:none;font-family:var(--sans);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  padding:.5rem 1.3rem;border-radius:100px;cursor:pointer;color:#666;transition:all .3s ease}
.dict-toggle button.active{background:var(--kiliki-red);color:#fff}
.dict-search{display:flex;gap:.7rem;flex-wrap:wrap;align-items:stretch}
.dict-search input{flex:1;min-width:220px;padding:.95rem 1.1rem;border:1px solid var(--line);background:#fff;font-family:var(--sans);font-size:1rem;color:var(--ink);transition:border-color .3s ease}
.dict-search input:focus{outline:none;border-color:var(--kiliki-red)}
.dict-search input.kk{font-family:"Kiliki",sans-serif;font-size:1.6rem;color:var(--kiliki-red);letter-spacing:.02em;
  -webkit-font-feature-settings:"liga" 1,"dlig" 1;font-feature-settings:"liga" 1,"dlig" 1}
.dict-hint{font-size:.8rem;color:var(--grey);margin-top:.7rem}

.dict-result{margin-top:1.8rem}
.dict-result .dr-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media(max-width:680px){.dict-result .dr-list{grid-template-columns:1fr}}
.dict-result .dr-count{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--grey);margin-bottom:.9rem}
.dict-result .dr-card{background:#fff;border:1px solid var(--line);border-left:3px solid var(--kiliki-red);border-radius:8px;padding:1.4rem 1.6rem;display:flex;align-items:flex-start;gap:1.3rem;flex-wrap:wrap}
.dict-result .dr-k{font-family:"Kiliki",sans-serif;font-size:3rem;line-height:1;color:var(--kiliki-red);flex-shrink:0;
  -webkit-font-feature-settings:"liga" 1,"dlig" 1;font-feature-settings:"liga" 1,"dlig" 1}
.dict-result .dr-info{flex:1;min-width:200px}
.dict-result .dr-info .dr-r{font-size:.95rem;color:#555;letter-spacing:.02em}
.dict-result .dr-info .dr-e{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:#111;margin-top:.15rem;line-height:1.2}
.dict-result .dr-info .dr-meta{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:.6rem;font-weight:500}
.dict-result .dr-info .dr-def{font-size:.92rem;color:#555;margin-top:.55rem;line-height:1.6}
.dict-result .dr-info .dr-tamil{font-family:var(--tamil);font-size:1.02rem;color:#333;margin-top:.5rem}
.dict-result .dr-empty{background:#fff;border:1px dashed var(--line);border-radius:8px;padding:2rem;text-align:center;color:var(--grey)}
.dict-result .dr-empty .de-k{font-family:"Kiliki",sans-serif;font-size:2.2rem;color:var(--gold-soft);margin-bottom:.5rem}

/* ---------- Quiz ---------- */
.quiz-wrap{max-width:680px;margin:0 auto}
.quiz-start,.quiz-card,.quiz-score{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 24px 50px -30px rgba(20,20,20,.3)}
.quiz-start{text-align:center;padding:3.4rem 2rem}
.quiz-start .qs-k{font-family:"Kiliki",sans-serif;font-size:4.2rem;color:var(--kiliki-red);line-height:1;margin-bottom:1rem;
  -webkit-font-feature-settings:"liga" 1,"dlig" 1;font-feature-settings:"liga" 1,"dlig" 1}
.quiz-start h2{font-family:var(--serif);font-size:clamp(1.6rem,3.4vw,2.2rem);font-weight:600;color:var(--ink-deep)}
.quiz-start p{color:#5a5a5a;max-width:34rem;margin:1rem auto 1.8rem;line-height:1.7}
.quiz-start .qs-modes{display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.8rem;font-size:.8rem;color:var(--grey)}
.quiz-start .qs-modes b{color:var(--kiliki-red)}

.quiz-card{padding:2rem 2rem 2.2rem}
.quiz-top{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--grey);font-weight:500}
.quiz-top .qt-score{color:var(--kiliki-red)}
.quiz-bar{height:6px;background:var(--line);border-radius:100px;margin:.9rem 0 1.8rem;overflow:hidden}
.quiz-bar i{display:block;height:100%;width:0;background:var(--kiliki-red);transition:width .4s cubic-bezier(.3,.7,.3,1)}
.quiz-ask{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);text-align:center;font-weight:500}
.quiz-prompt{text-align:center;margin:.7rem 0 1.7rem}
.quiz-prompt .qp-k{font-family:"Kiliki",sans-serif;font-size:clamp(3.2rem,10vw,4.6rem);color:var(--kiliki-red);line-height:1;
  -webkit-font-feature-settings:"liga" 1,"dlig" 1;font-feature-settings:"liga" 1,"dlig" 1}
.quiz-prompt .qp-e{font-family:var(--serif);font-size:clamp(1.8rem,5vw,2.6rem);font-weight:600;color:var(--ink-deep);line-height:1.15}
.quiz-prompt .qp-sub{font-size:.9rem;color:var(--grey);margin-top:.5rem;letter-spacing:.02em}
.quiz-options{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
@media(max-width:520px){.quiz-options{grid-template-columns:1fr}}
.quiz-opt{border:1px solid var(--line);background:#fff;border-radius:12px;padding:1rem 1.1rem;cursor:pointer;font-family:var(--sans);
  font-size:1rem;color:var(--ink);text-align:center;transition:transform .18s ease,border-color .18s ease,background .18s ease;min-height:56px;
  display:flex;align-items:center;justify-content:center;gap:.5rem}
.quiz-opt:hover:not([disabled]){border-color:var(--kiliki-red);transform:translateY(-2px)}
.quiz-opt.kk{font-family:"Kiliki",sans-serif;font-size:2rem;color:var(--kiliki-red);
  -webkit-font-feature-settings:"liga" 1,"dlig" 1;font-feature-settings:"liga" 1,"dlig" 1}
.quiz-opt .opt-sub{font-family:var(--sans);font-size:.72rem;color:var(--grey);letter-spacing:.02em}
.quiz-opt.correct{background:#eaf6ee;border-color:#2f9e5b;color:#1f7a44}
.quiz-opt.correct.kk{color:#1f7a44}
.quiz-opt.wrong{background:#fbebec;border-color:var(--kiliki-red);color:var(--kiliki-red)}
.quiz-opt[disabled]{cursor:default}
.quiz-feedback{text-align:center;margin-top:1.3rem;min-height:1.4rem;font-weight:500;font-size:.95rem}
.quiz-feedback.ok{color:#2f9e5b}
.quiz-feedback.no{color:var(--kiliki-red)}
.quiz-next{text-align:center;margin-top:1rem}

.quiz-score{text-align:center;padding:3rem 2rem}
.quiz-score .qsc-logo{height:60px;width:auto;margin:0 auto 1.2rem;display:block}
.quiz-score .qsc-k{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:500}
.quiz-score .qsc-big{font-family:var(--serif);font-size:4.4rem;font-weight:700;color:var(--kiliki-red);line-height:1;margin-top:.4rem}
.quiz-score .qsc-big span{font-size:1.6rem;color:var(--grey);font-weight:400}
.quiz-score .qsc-msg{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--ink-deep);margin-top:.6rem}
.quiz-score .qsc-actions{margin-top:2rem;display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* Category browse */
.cat-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}
.cat-count{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--grey);margin:-.6rem 0 1.4rem}
.word-card .wc-e2{font-size:.72rem;color:var(--grey);margin-top:.15rem}

/* ---------- Word cards (popular words) ---------- */
.word-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1rem}
.word-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:1.7rem 1rem 1.4rem;text-align:center;
  transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}
.word-card:hover{transform:translateY(-5px);box-shadow:0 16px 36px -18px rgba(20,20,20,.28);border-color:var(--kiliki-red)}
.word-card .wc-k{font-family:"Kiliki",sans-serif;font-size:2.7rem;line-height:1;color:var(--kiliki-red);display:block;
  -webkit-font-feature-settings:"liga" 1,"dlig" 1;font-feature-settings:"liga" 1,"dlig" 1}
.word-card .wc-r{font-size:.9rem;color:#555;margin-top:.6rem;letter-spacing:.03em}
.word-card .wc-e{font-size:1.02rem;color:#111;font-weight:500;margin-top:.1rem}

/* ---------- Brand logo / mask icon ---------- */
.brand{gap:.6rem;align-items:center}
.brand-ic{height:38px;width:auto;display:block}
.brand .bm-name{display:inline-flex;align-items:baseline;gap:.34em;font-size:.66rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink);font-weight:500;line-height:1}
.brand .bm-word{font-family:var(--serif);font-size:1.4rem;font-weight:700;letter-spacing:.01em;color:var(--kiliki-red);text-transform:none}
nav.site-nav.scrolled .brand-ic{height:34px}
.foot-logo{height:50px;width:auto;margin-bottom:.4rem}
@media(max-width:520px){.brand .bm-word{font-size:1.2rem}.brand-ic{height:32px}.brand .bm-name{font-size:.6rem}}

/* ---------- Hero mask feature (home) ---------- */
.hero-mask{position:absolute;right:4vw;top:50%;transform:translateY(-50%);width:min(40vw,460px);height:auto;
  z-index:0;opacity:0;transition:opacity 1.1s ease,transform 1.1s ease;filter:drop-shadow(0 30px 60px rgba(160,30,30,.18))}
.hero-mask.show{opacity:1}
@media(max-width:980px){
  .hero-mask{position:relative;right:auto;top:auto;transform:none;width:min(62%,300px);margin:2.4rem auto 0;display:block}
  .home-hero{align-items:center;text-align:left}
  .home-hero .hero-text{max-width:none}
}
@media(max-width:560px){.hero-mask{width:64%}}

/* ---------- Nav dropdown ---------- */
.nav-links li.has-drop{position:relative}
.nav-links .drop-toggle{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer}
.nav-links .drop-toggle svg{width:9px;height:9px;transition:transform .3s ease}
.nav-links li.has-drop.open .drop-toggle svg{transform:rotate(180deg)}
.nav-links .drop-menu{position:absolute;top:calc(100% + .9rem);left:50%;transform:translateX(-50%) translateY(8px);min-width:170px;
  background:#fff;border:1px solid var(--line);box-shadow:0 20px 44px -22px rgba(40,40,40,.4);padding:.5rem 0;
  opacity:0;visibility:hidden;transition:opacity .25s ease,transform .25s ease;z-index:1001}
.nav-links li.has-drop.open .drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-links li.has-drop.open .drop-toggle svg{transform:rotate(180deg)}
.nav-links .drop-menu a{display:block;padding:.6rem 1.3rem;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);white-space:nowrap}
.nav-links .drop-menu a::after{display:none}
.nav-links .drop-menu a:hover{background:var(--paper-warm);color:var(--gold)}
@media(max-width:860px){
  .nav-links .drop-menu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;background:transparent;
    padding:.3rem 0 .3rem 1rem;min-width:0;border-left:1px solid #555;margin-top:.4rem}
  .nav-links .drop-menu a{color:#ccc;padding:.5rem 0}
  .nav-links li.has-drop{width:100%}
}
