:root{--background: #fff8f1;--surface: #fffdf8;--surface-strong: #fff1df;--border: #f0d8c7;--text: #4f3d33;--muted: #806b5c;--accent: #b6642f;--accent-strong: #8f451b;--shadow: 0 24px 70px rgba(110, 80, 58, .12);color-scheme:light}*{box-sizing:border-box}html{min-height:100%;scroll-behavior:smooth}body{min-height:100%;margin:0;overflow-x:hidden;background:radial-gradient(circle at top left,rgba(255,220,186,.5),transparent 28%),radial-gradient(circle at top right,rgba(255,235,173,.34),transparent 24%),linear-gradient(180deg,#fff9f3,#fff7f0 35%,#fff2e6);color:var(--text);font-family:ui-serif,Songti TC,"Noto Serif TC",PMingLiU,Georgia,serif}a{color:inherit;text-decoration:none}:where(a,button,input,select,textarea,[tabindex]):focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}main{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:32px 0 56px}@media(prefers-reduced-motion:no-preference){main>*{animation:fade-in .42s ease backwards}}.site-header,.site-footer{width:min(1120px,calc(100% - 32px));margin:0 auto}.site-header{display:flex;align-items:center;flex-wrap:wrap;justify-content:space-between;gap:20px;padding:20px 0}.brand{font-size:1.2rem;font-weight:800}nav{display:flex;gap:14px;color:var(--muted);font-size:.95rem}.language-toggle{display:inline-flex;border:1px solid var(--border);border-radius:999px;background:#fffdf8cc;overflow:hidden}.language-toggle__item{padding:6px 12px;color:var(--muted);font-size:.87rem;font-weight:700}.language-toggle__item.is-active{background:var(--surface-strong);color:var(--accent-strong)}.site-footer{border-top:1px solid var(--border);color:var(--muted);padding:28px 0 36px}.site-footer__inner{display:flex;align-items:center;flex-wrap:wrap;justify-content:space-between;gap:14px 22px}.site-footer__inner p{margin:0}.site-footer__links{display:flex;flex-wrap:wrap;gap:10px 16px}.site-footer__links a{color:var(--accent-strong);font-weight:700}.site-footer__copyright{font-size:.92rem}.hero,.story-detail{border-bottom:1px solid var(--border);background:linear-gradient(135deg,#fffdf89e,#fff0e5ad);padding:clamp(28px,5vw,56px)}.hero h1,.story-detail h1{max-width:780px;margin:10px 0 18px;font-size:4rem;line-height:1;overflow-wrap:anywhere;text-wrap:balance}.hero p,.story-detail p{max-width:760px;color:var(--muted);font-size:1.08rem;line-height:1.8}.eyebrow{margin:0;color:var(--accent);font-size:.83rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.section{padding-top:42px}.section__heading{margin-bottom:18px}.section__heading h2{margin:8px 0 0;font-size:1.8rem}.story-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}.story-card{display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.8);border-radius:12px;background:#fffdf8d6;box-shadow:0 18px 48px #6e503a1a;overflow:hidden;transition:transform .22s ease,box-shadow .22s ease}.story-card:hover{transform:translateY(-4px);box-shadow:0 22px 56px #6e503a2e}.story-card__media{display:block;line-height:0}.story-card__media .story-illustration{border-radius:0;border:none;border-bottom:1px solid var(--border)}.story-card__body{padding:20px 22px 22px}.story-card h2{margin:8px 0 4px;font-size:1.45rem}.story-card p{color:var(--muted);line-height:1.7}.story-card__meta,.story-card__subtitle,.story-detail__subtitle{color:var(--accent);font-weight:700}.story-card__meta a{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}.story-card__tags{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 2px;font-size:.9rem}.story-card__tags a{border:1px solid rgba(182,100,47,.22);border-radius:999px;background:#fff1df9e;color:var(--accent-strong);padding:4px 9px;font-weight:800}.search-panel{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,280px) auto;gap:10px;border:1px solid var(--border);border-radius:12px;background:#fffdf8d6;padding:14px}.search-panel__field{display:flex;flex-direction:column;gap:6px;color:var(--muted);font-size:.9rem}.search-panel input,.search-panel select{min-height:42px;border:1px solid var(--border);border-radius:10px;padding:0 12px;font:inherit;background:#fffdf8;color:var(--text)}.empty-hint{margin:4px 0 18px;color:var(--muted)}.source-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.source-card{border:1px solid var(--border);border-radius:10px;background:#fffdf8d6;padding:20px}.source-card h3{margin:0 0 8px}.source-card p{color:var(--muted);line-height:1.7}.breadcrumb{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:18px;color:var(--muted);font-size:.9rem}.breadcrumb a{color:var(--accent-strong);font-weight:800}.breadcrumb a:hover{text-decoration:underline;text-underline-offset:3px}.button,.back-link{display:inline-flex;align-items:center;justify-content:center;border:1px solid #f3d8c5;border-radius:999px;background:var(--surface-strong);color:var(--accent-strong);font-weight:800}.button{min-height:44px;margin-top:10px;padding:0 18px}.back-link{min-height:38px;padding:0 14px}.back-link--ghost{border-style:dashed;font-size:.85rem;opacity:.85}.story-detail__hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,360px);gap:28px;align-items:center}.story-detail__hero>*{min-width:0}.story-illustration{display:grid;place-items:center;overflow:hidden;border:1px solid var(--border);border-radius:18px;background:radial-gradient(circle at 30% 30%,rgba(255,224,190,.85),transparent 58%),radial-gradient(circle at 70% 70%,rgba(255,206,178,.75),transparent 58%),#fff8ef;font-size:4rem}.story-illustration--hero{width:100%;max-width:360px;aspect-ratio:1 / 1}.story-illustration--card{width:100%;aspect-ratio:16 / 9;font-size:3rem}.story-illustration--has-image{background:#fff8ef}.story-illustration img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.story-meta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px;color:var(--muted)}.story-prose{margin-top:30px}.story-prose h2{margin:30px 0 10px;font-size:1.45rem}.story-prose p{margin:0 0 18px;overflow-wrap:anywhere}.story-prose ul{margin:0 0 20px;padding-left:1.4rem}.story-prose li{margin-bottom:8px;line-height:1.8}.story-prose a{color:var(--accent-strong);font-weight:700;text-decoration:underline;text-underline-offset:3px}.listing-page{min-height:52vh}.legal-page{max-width:720px;margin:0 auto}.legal-hero{border-bottom:1px solid var(--border);background:linear-gradient(135deg,#fffdf8b3,#fff0e5b8);padding:clamp(26px,5vw,42px)}.legal-hero h1{margin:8px 0 14px;font-size:clamp(2.25rem,6vw,3.1rem);line-height:1.05}.legal-hero p{margin:0;color:var(--muted);line-height:1.8}.legal-prose{font-size:1.03rem;line-height:1.85}.legal-note{color:var(--muted);font-size:.95rem}.contact-mail{font-size:1.18rem;font-weight:800}.not-found-page{text-align:center}.not-found-page__mark{font-size:4rem;line-height:1;margin-bottom:18px}.info-panel,.source-panel{margin-top:20px;border:1px solid var(--border);border-radius:10px;background:#fffdf8b8;padding:18px}.info-panel h2,.source-panel h2{margin:0 0 8px}.read-aloud,.youtube-embed,.ad-slot{margin-top:20px;border:1px solid var(--border);border-radius:10px;background:#fffdf8b8;padding:18px}.read-aloud h2,.youtube-embed h2{margin:0 0 8px}.read-aloud p,.youtube-embed p,.ad-slot p{color:var(--muted)}.story-grid__ad{grid-column:1 / -1}.read-aloud__controls{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.read-aloud__button{margin-top:0}.read-aloud__status{margin:0;font-size:.95rem}.youtube-embed__frame{position:relative;width:100%;padding-top:56.25%;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#f5ede1}.youtube-embed__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.adsbygoogle{min-height:120px}.ad-placeholder{display:grid;min-height:120px;place-items:center;border:1px dashed rgba(182,100,47,.52);border-radius:8px;background:#b6642f0d;color:var(--muted);padding:24px;text-align:center}.pagination{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:center;margin-top:24px;color:var(--muted);font-weight:800}.source-links{display:flex;flex-wrap:wrap;gap:10px}.source-links a{text-decoration:underline;text-underline-offset:3px}.story-detail__backline{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.cookie-banner{position:fixed;inset:auto 0 0;z-index:100;display:flex;flex-wrap:wrap;gap:12px 18px;align-items:center;justify-content:space-between;padding:14px 22px;background:#4f3d33f2;color:#fff8f1;border-top:2px solid #b6642f;box-shadow:0 -8px 24px #00000026;font-size:.9rem}.cookie-banner p{max-width:800px;margin:0}.cookie-banner a{color:#ffc89c;text-decoration:underline;text-underline-offset:3px}.cookie-banner__actions{display:flex;gap:10px}.cookie-banner button{border:0;border-radius:999px;background:#b6642f;color:#fff;cursor:pointer;font-weight:700;padding:8px 16px}.cookie-banner button.ghost{border:1px solid rgba(255,255,255,.4);background:transparent;color:#fff8f1}.cookie-banner button:hover{filter:brightness(1.1)}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.site-header{align-items:flex-start;flex-direction:column}main{width:min(1120px,calc(100% - 24px));padding-top:20px}.hero,.story-detail{width:100%;max-width:100%;overflow:hidden;padding:28px 16px}.search-panel,.story-detail__hero{grid-template-columns:1fr}.story-detail__hero,.story-prose{width:100%;max-width:100%;min-width:0}.story-illustration--hero{max-width:100%;aspect-ratio:16 / 9;font-size:2.6rem}.story-illustration--card{font-size:2.4rem}.hero h1,.story-detail h1{max-width:100%;font-size:clamp(2rem,9.5vw,2.35rem);line-height:1.08;text-wrap:wrap;word-break:normal;overflow-wrap:break-word}.site-footer__inner{align-items:flex-start;flex-direction:column}.site-footer__links{max-width:280px}.cookie-banner{align-items:stretch;flex-direction:column}.cookie-banner__actions{justify-content:stretch}.cookie-banner__actions button{flex:1}}
