/*
Theme Name: Story That Touch
Theme URI: https://github.com/LeDat0709/trangtruyenquetoi
Author: LeDat0709
Description: Senior-friendly story-reading theme — light / sepia / dark, adjustable text size (Aa), clean cards and a comfortable 2-column reading layout. Built for readers 50-60+.
Version: 1.0.0
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: storythattouch
*/

:root{
  --bg:#FAF7F0; --surface:#FFFFFF; --edge:#E5DAC2; --ink:#23201A; --soft:#3F382C;
  --accent:#5C3D15; --accent-hover:#3F2A0E; --forest:#1F3D2F; --forest-ink:#F4ECD8;
  --shadow:0 1px 2px rgba(35,32,26,.06), 0 6px 18px rgba(35,32,26,.08);
  --shadow-hover:0 2px 6px rgba(35,32,26,.10), 0 18px 42px rgba(35,32,26,.15);
  --radius:14px; --maxw:1240px; --fs:18px;
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
:root[data-theme="sepia"]{ --bg:#F4ECD8; --surface:#FBF5E6; --edge:#DCCBA6; --ink:#2B2419; --soft:#483D2A; --accent:#5C3D15; --forest:#244536; }
:root[data-theme="dark"]{ --bg:#14130F; --surface:#1E1C16; --edge:#3A352B; --ink:#ECE4D0; --soft:#C3B9A0; --accent:#E8C188; --accent-hover:#F2D5A6; --forest:#16271D; --forest-ink:#E8C188;
  --shadow:0 1px 2px rgba(0,0,0,.4), 0 6px 18px rgba(0,0,0,.45); --shadow-hover:0 2px 6px rgba(0,0,0,.5), 0 18px 42px rgba(0,0,0,.6); }

*{box-sizing:border-box}
html{font-size:var(--fs)}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .2s,color .2s}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-hover)}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--forest);outline-offset:2px;border-radius:4px}
:root[data-theme="dark"] :focus-visible{outline-color:var(--accent)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.skip{position:absolute;left:-9999px}.skip:focus{left:12px;top:12px;z-index:200;background:var(--surface);padding:10px 14px;border-radius:8px;box-shadow:var(--shadow)}
@media (prefers-reduced-motion:reduce){*{transition-duration:.001ms!important;animation-duration:.001ms!important}}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:var(--surface);border-bottom:1px solid var(--edge)}
.bar{display:flex;align-items:center;gap:14px;min-height:64px;flex-wrap:wrap;padding:8px 0}
.brand{display:flex;align-items:center;gap:11px;color:var(--ink)}
.brand .mark{width:36px;height:36px;color:var(--accent);flex:none}
.brand .n{font-family:var(--serif);font-weight:700;font-size:1.28rem;line-height:1.05}
.brand .k{font-family:var(--sans);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700}
.nav{display:flex;gap:6px;flex-wrap:wrap}
.nav a{font-family:var(--sans);font-weight:600;font-size:.92rem;color:var(--soft);padding:8px 11px;border-radius:9px;min-height:44px;display:inline-flex;align-items:center}
.nav a:hover{color:var(--ink);background:rgba(92,61,21,.08)}
.spacer{flex:1 1 auto}
.tools{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.search{display:flex;align-items:center;background:var(--bg);border:1px solid var(--edge);border-radius:999px;padding:2px 4px 2px 12px}
.search input{border:0;background:none;color:var(--ink);font-size:.9rem;padding:8px 4px;min-width:120px;outline:none;font-family:var(--sans)}
.search button{border:0;background:none;color:var(--accent);min-width:40px;min-height:40px;border-radius:999px}
.grp{display:flex;align-items:center;gap:2px;background:var(--bg);border:1px solid var(--edge);border-radius:999px;padding:2px}
.grp .lbl{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--soft);padding:0 8px}
.seg{min-width:42px;min-height:40px;border:0;background:none;border-radius:999px;color:var(--soft);font-weight:700;line-height:1}
.seg[aria-pressed="true"]{background:var(--accent);color:var(--bg)}
:root[data-theme="dark"] .seg[aria-pressed="true"]{color:#14130F}
.seg.s{font-size:.78rem}.seg.m{font-size:.95rem}.seg.l{font-size:1.1rem}
.theme-sel{font-family:var(--sans);font-size:.85rem;padding:8px 10px;min-height:40px;border:1px solid var(--edge);border-radius:999px;background:var(--bg);color:var(--ink)}

/* Sections */
main{min-height:60vh;padding-bottom:70px}
.intro{text-align:center;max-width:760px;margin:0 auto;padding:48px 0 8px}
.intro .k{font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:700}
.intro h1{font-family:var(--serif);font-weight:800;font-size:clamp(2rem,5.5vw,3.1rem);line-height:1.1;margin:12px 0 0;text-wrap:balance}
.intro p{color:var(--soft);font-size:1.1rem;margin:16px auto 0;max-width:56ch}
.sechead{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:48px 0 18px;flex-wrap:wrap}
.sechead h2{font-family:var(--serif);font-size:1.55rem;font-weight:700;margin:0}
.eyebrow{font-family:var(--sans);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700}

/* Category chips */
.cats{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}
.cats a{font-family:var(--sans);font-weight:600;font-size:.9rem;color:var(--ink);background:var(--surface);border:1px solid var(--edge);border-radius:999px;padding:9px 16px;min-height:44px;display:inline-flex;align-items:center;gap:7px}
.cats a:hover{border-color:var(--accent);color:var(--accent)}
.cats .c{font-family:var(--sans);font-size:.78rem;color:var(--accent);font-weight:700}

/* Card grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(min-width:1300px){.grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:880px){.grid{grid-template-columns:repeat(2,1fr);gap:20px}}
@media(max-width:560px){.grid{grid-template-columns:1fr}}
.card{background:var(--surface);border:1px solid var(--edge);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow);position:relative;transition:transform .35s,box-shadow .35s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover)}
.card .ph{aspect-ratio:3/2;background:#e9e1d0;overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .ph img{transform:scale(1.04)}
.card .bd{padding:16px 18px 18px;display:flex;flex-direction:column;gap:9px;flex:1}
.chip{align-self:flex-start;font-family:var(--sans);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);border:1px solid var(--edge);border-radius:6px;padding:3px 9px}
.card h3{font-family:var(--serif);font-size:1.1rem;line-height:1.3;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card h3 a{color:var(--ink)} .card h3 a:hover{color:var(--accent)}
.card p{margin:0;font-family:var(--sans);font-size:.88rem;color:var(--soft);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card .meta{margin-top:auto;font-family:var(--sans);font-size:.74rem;color:var(--soft);display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.card .meta .dot{width:3px;height:3px;border-radius:50%;background:var(--accent)}
.readlink{font-family:var(--sans);font-weight:700;font-size:.8rem;color:var(--accent)}

/* Pagination */
.pagination{margin:34px 0;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.pagination .page-numbers{font-family:var(--sans);font-weight:600;padding:9px 14px;min-height:44px;display:inline-flex;align-items:center;border:1px solid var(--edge);border-radius:9px;background:var(--surface);color:var(--ink)}
.pagination .current{background:var(--accent);color:var(--bg);border-color:var(--accent)}

/* Single (reading) */
.article-wrap{display:grid;grid-template-columns:minmax(0,720px) 320px;gap:54px;justify-content:center;align-items:start;padding-top:34px}
@media(max-width:1000px){.article-wrap{grid-template-columns:1fr;gap:34px}}
.article{max-width:720px}
.article .hero{border-radius:var(--radius);overflow:hidden;border:1px solid var(--edge);margin:0 0 22px;aspect-ratio:16/8;background:#e9e1d0}
.article .hero img{width:100%;height:100%;object-fit:cover}
.article h1{font-family:var(--serif);font-weight:800;font-size:clamp(1.9rem,4.6vw,2.7rem);line-height:1.14;margin:14px 0 12px;text-wrap:balance}
.byline{font-family:var(--sans);font-size:.9rem;color:var(--soft);display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:8px}
.byline a{color:var(--accent);font-weight:600}
.byline .dot{width:3px;height:3px;border-radius:50%;background:var(--accent)}
.listen{margin-left:6px;font-family:var(--sans);font-weight:700;font-size:.82rem;color:var(--accent);background:none;border:1px solid var(--accent);border-radius:22px;padding:8px 14px;min-height:44px;display:inline-flex;align-items:center;gap:7px}
.listen:hover{background:var(--accent);color:var(--surface)}
.entry{font-family:var(--serif);font-size:1.14rem;line-height:1.85;margin-top:26px}
.entry p{margin:0 0 1.25em}
.entry h2,.entry h3{font-family:var(--serif);line-height:1.25;margin:1.5em 0 .5em}
.entry img{border-radius:10px;margin:1.2em 0}
.entry blockquote{margin:1.4em 0;padding:6px 0 6px 20px;border-left:3px solid var(--accent);font-style:italic;color:var(--soft)}
.entry a{text-decoration:underline}
.sidebar{position:sticky;top:84px;display:flex;flex-direction:column;gap:18px}
.scard{background:var(--surface);border:1px solid var(--edge);border-radius:12px;padding:18px}
.scard h4{font-family:var(--sans);font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--soft);margin:0 0 12px;font-weight:700}
.authorcard{display:flex;gap:12px;align-items:center}
.avatar{width:48px;height:48px;border-radius:50%;background:var(--forest);color:var(--forest-ink);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;font-size:1.2rem;flex:none}
.authorcard .nm{font-family:var(--serif);font-weight:700}
.srel{display:flex;gap:11px;padding:9px 0;border-top:1px solid var(--edge)}
.srel:first-of-type{border-top:0}
.srel img{width:64px;height:44px;object-fit:cover;border-radius:7px;flex:none}
.srel a{font-family:var(--serif);font-size:.95rem;line-height:1.3;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.srel a:hover{color:var(--accent)}
.share a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--edge);color:var(--accent);margin-right:6px}
.backlink{font-family:var(--sans);font-weight:600;color:var(--accent);min-height:44px;display:inline-flex;align-items:center;gap:6px}

/* Aa text-size levels (set on <html data-fs>) */
:root[data-fs="s"]{--fs:16px}
:root[data-fs="m"]{--fs:18px}
:root[data-fs="l"]{--fs:21px}

/* Brand text stack + reading progress bar */
.brand .bt{display:flex;flex-direction:column;line-height:1.05}
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);z-index:200;transition:width .12s linear}

/* Featured block (front page) */
.feature{display:grid;grid-template-columns:1.25fr 1fr;background:var(--surface);border:1px solid var(--edge);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin:10px 0 6px}
@media(max-width:760px){.feature{grid-template-columns:1fr}}
.feature .fimg{aspect-ratio:16/10;background:#e9e1d0;overflow:hidden}
.feature .fimg img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.feature:hover .fimg img{transform:scale(1.03)}
.feature .fbd{padding:28px 32px;display:flex;flex-direction:column;gap:13px;justify-content:center}
.feature .chip{align-self:flex-start}
.feature h2{font-family:var(--serif);font-size:clamp(1.45rem,3vw,2.05rem);line-height:1.16;margin:0}
.feature h2 a{color:var(--ink)} .feature h2 a:hover{color:var(--accent)}
.feature p{margin:0;color:var(--soft);font-size:1.02rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* Top Stories — tabs + ranked list */
.toptabs{display:inline-flex;gap:4px;background:var(--bg);border:1px solid var(--edge);border-radius:999px;padding:4px}
.toptab{border:0;background:none;font-family:var(--sans);font-weight:700;font-size:.85rem;color:var(--soft);padding:8px 16px;min-height:42px;border-radius:999px}
.toptab[aria-selected="true"]{background:var(--accent);color:var(--bg)}
:root[data-theme="dark"] .toptab[aria-selected="true"]{color:#14130F}
.toplist{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:18px}
@media(max-width:760px){.toplist{grid-template-columns:1fr}}
.toprow{display:flex;gap:14px;align-items:center;background:var(--surface);border:1px solid var(--edge);border-radius:12px;padding:12px 14px;transition:border-color .25s}
.toprow:hover{border-color:var(--accent)}
.toprow .rank{font-family:var(--serif);font-weight:800;font-size:1.55rem;color:var(--accent);width:28px;text-align:center;flex:none}
.toprow .tph{width:74px;height:52px;border-radius:8px;flex:none;overflow:hidden;background:#e9e1d0}
.toprow .tph img{width:100%;height:100%;object-fit:cover}
.toprow .ti{font-family:var(--serif);font-weight:700;font-size:1rem;line-height:1.25;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.toprow .ti a{color:var(--ink)} .toprow .ti a:hover{color:var(--accent)}
.toprow .mt{font-family:var(--sans);font-size:.74rem;color:var(--soft);margin-top:3px}

/* Author archive header + simple page */
.archead{padding:40px 0 8px;border-bottom:1px solid var(--edge);margin-bottom:8px}
.archead h1{font-family:var(--serif);font-size:clamp(1.7rem,4vw,2.4rem);margin:0 0 8px}
.archead p{color:var(--soft);margin:0;max-width:62ch}
.page-narrow{max-width:760px;margin:0 auto;padding:30px 0}
.page-narrow h1{font-family:var(--serif);font-size:clamp(1.8rem,4.5vw,2.6rem);line-height:1.14;margin:0 0 18px}
.page-narrow .entry{font-family:var(--serif);font-size:1.12rem;line-height:1.8}
.empty{text-align:center;color:var(--soft);padding:60px 0}

/* Footer */
.site-footer{background:var(--forest);color:var(--forest-ink);padding:30px 0;margin-top:40px}
.site-footer .wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:var(--sans);font-size:.85rem;align-items:center}
.site-footer .fnav{display:flex;gap:16px;flex-wrap:wrap}
.site-footer .fb{font-family:var(--serif);font-weight:700;font-size:1.1rem}
.site-footer a{color:var(--forest-ink);text-decoration:underline}
