:root{
  --paper:#f8f4ee;
  --paper-2:#efe7dc;
  --ink:#241f1c;
  --muted:#6e625b;
  --line:#d8cabe;
  --soft-line:#e8ded5;
  --accent:#8b5e3c;
  --accent-dark:#5a3525;
  --danger:#9d3f36;
  --ok:#5b7661;
  --white:#fffdf9;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--paper);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic",YuGothic,Meiryo,sans-serif;line-height:1.85;letter-spacing:.015em}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.wrap{width:min(1120px,calc(100% - 40px));margin:auto}.age{background:#241f1c;color:#f7efe6;text-align:center;font-size:12px;line-height:1.6;padding:8px 14px}.header{background:rgba(248,244,238,.96);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}.head{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:flex;align-items:center;gap:0;font-weight:700;font-size:21px;letter-spacing:.04em}.brand small{display:block;margin-top:1px;font-size:11px;font-weight:500;letter-spacing:.06em;color:var(--muted)}.nav{display:flex;align-items:center;gap:18px;font-size:13px;color:#4f4540}.nav a{white-space:nowrap}.nav a:hover{color:var(--accent-dark)}.nav .mini{border:1px solid var(--ink);padding:7px 12px;color:var(--ink)}
.hero{padding:0 0 64px}.hero-copy{padding:10px 0}.eyebrow,.section-label{font-size:12px;letter-spacing:.12em;color:var(--accent-dark);font-weight:700;margin:0 0 18px}.hero h1{font-family:Georgia,"Times New Roman","Yu Mincho",YuMincho,serif;font-size:clamp(42px,5vw,68px);line-height:1.18;letter-spacing:.01em;margin:0 0 24px;font-weight:500}.lead{font-size:17px;color:#4e433e;margin:0 0 26px;max-width:620px}.actions{display:flex;gap:12px;flex-wrap:wrap;margin:26px 0 18px}.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--ink);padding:12px 18px;font-size:14px;font-weight:700;line-height:1.2}.btn.primary{background:var(--ink);color:#fff}.btn.secondary,.btn.btn-white{background:transparent;color:var(--ink)}.btn:hover{opacity:.84}.hero-policy{margin:16px 0 0;color:var(--muted);font-size:12px}.hero-fullbleed{position:relative;overflow:hidden;isolation:isolate}.hero-media{position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(20,15,13,.72) 0%,rgba(20,15,13,.54) 34%,rgba(20,15,13,.22) 62%,rgba(20,15,13,.40) 100%),linear-gradient(180deg,rgba(20,15,13,.08),rgba(20,15,13,.18)),url("images/common/hero-cafe-night.webp");background-size:cover;background-position:center center;transform:scale(1.02)}.hero-stack{position:relative;z-index:1;min-height:640px;display:flex;align-items:flex-end;padding:92px 0 56px}.hero-on-image{max-width:640px;color:#fff}.hero-on-image .eyebrow{color:rgba(255,247,240,.82)}.hero-on-image .lead{color:rgba(255,247,240,.88)}.btn.btn-white{background:#fff;color:var(--ink);border-color:#fff}.btn.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.75)}.btn.btn-ghost:hover,.btn.btn-white:hover{opacity:.9}.hero-on-image .hero-policy{color:rgba(255,247,240,.78)}.hero-caption{margin:12px 0 0;color:rgba(255,247,240,.68);font-size:11px}.section{padding:64px 0;border-top:1px solid var(--soft-line)}.first-section{padding-top:36px}.muted-section{background:#f1ebe4}.compact-section{padding-top:52px}.editorial-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(300px,.9fr);gap:54px;align-items:start}.lead-story{display:block;border-top:2px solid var(--ink);padding-top:22px}.lead-story h2{font-family:Georgia,"Times New Roman","Yu Mincho",YuMincho,serif;font-size:clamp(30px,3.2vw,48px);line-height:1.28;font-weight:500;letter-spacing:.01em;margin:10px 0 18px}.lead-story p{margin:0;color:var(--muted);max-width:720px}.tag{display:inline-block;font-size:12px;color:var(--accent-dark);font-weight:700}.tag.danger{color:var(--danger)}.tag.green{color:var(--ok)}.story-index{border-top:1px solid var(--ink)}.story-index a{display:block;padding:20px 0;border-bottom:1px solid var(--line)}.story-index span{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}.story-index strong{display:block;font-size:18px;line-height:1.55}.plain-title{display:flex;align-items:flex-end;justify-content:space-between;gap:28px;margin-bottom:28px}.plain-title h2{font-family:Georgia,"Times New Roman","Yu Mincho",YuMincho,serif;font-size:34px;font-weight:500;line-height:1.3;margin:0}.plain-title p{margin:0;color:var(--muted);max-width:440px}.number-list{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--ink);border-left:1px solid var(--line)}.number-list a{min-height:210px;padding:22px 20px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,253,249,.42)}.number-list span{display:block;font-family:Georgia,"Times New Roman",serif;font-size:26px;color:var(--accent);margin-bottom:26px}.number-list h3{font-size:18px;line-height:1.45;margin:0 0 10px}.number-list p{font-size:13px;color:var(--muted);margin:0;line-height:1.75}.two-columns{display:grid;grid-template-columns:1fr 1fr;gap:44px}.text-column{display:block;border-top:1px solid var(--ink);padding-top:24px}.text-column h2{font-family:Georgia,"Times New Roman","Yu Mincho",YuMincho,serif;font-size:34px;line-height:1.35;font-weight:500;margin:10px 0 14px}.text-column p{margin:0;color:var(--muted)}.simple-links{border-top:1px solid var(--ink)}.simple-links a{display:grid;grid-template-columns:240px 1fr;gap:24px;padding:22px 0;border-bottom:1px solid var(--line)}.simple-links strong{font-size:18px}.simple-links span{color:var(--muted)}.two{display:grid;grid-template-columns:1fr 1fr;gap:28px}.panel,.article,.side-card,.list-card,.card,.app-box,.note-box,.article-notice,.filter{background:var(--white);border:1px solid var(--line)}.panel{padding:30px}.panel h2{font-family:Georgia,"Times New Roman","Yu Mincho",YuMincho,serif;font-size:30px;font-weight:500;line-height:1.3;margin:0 0 12px}.panel p{color:var(--muted);margin:0 0 20px}.checklist{padding-left:1.2em;margin:18px 0 0}.checklist li{margin:.35em 0}.footer{border-top:1px solid var(--line);padding:34px 0 46px;background:#eee5da;color:var(--muted);font-size:12px}.footlinks{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px}.footlinks a{text-decoration:underline;text-underline-offset:3px}
.page-head{padding:54px 0 30px}.page-head h1{font-family:Georgia,"Times New Roman","Yu Mincho",YuMincho,serif;font-size:clamp(34px,4vw,52px);line-height:1.25;font-weight:500;margin:0 0 12px}.category-grid{display:grid;grid-template-columns:250px 1fr;gap:30px;padding:30px 0 70px}.filter{padding:22px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chips span{border:1px solid var(--line);padding:6px 10px;font-size:12px;background:#fff}.body{display:grid;gap:16px}.list-card{display:grid;grid-template-columns:170px 1fr;gap:22px;padding:16px}.list-card h3{font-size:22px;line-height:1.45;margin:6px 0 8px}.list-card p{color:var(--muted);margin:0}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.card a{display:block}.card .body{padding:18px}.card h3{font-size:20px;line-height:1.45;margin:6px 0 8px}.card p{margin:0;color:var(--muted)}.thumb,.visual{background:#d6c5b6;min-height:170px;position:relative}.thumb.t2{background:#cbb8aa}.thumb.t3{background:#bda99a}.thumb.t4{background:#dfd2c4}.thumb.cafe,.thumb.message,.thumb.night,.editorial-thumb{background:#cab7a8}.article-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:34px;padding:26px 0 74px}.article-layout.article-single{grid-template-columns:minmax(0,860px);justify-content:center}.breadcrumb{padding-top:18px;font-size:12px;color:var(--muted)}.article{padding:34px}.article-head h1{font-family:Georgia,"Times New Roman","Yu Mincho",YuMincho,serif;font-size:clamp(32px,4vw,50px);line-height:1.32;font-weight:500;margin:12px 0}.meta,.labelrow{display:flex;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:12px}.content h2{font-family:Georgia,"Times New Roman","Yu Mincho",YuMincho,serif;font-size:30px;font-weight:500;margin:42px 0 14px;padding-top:20px;border-top:1px solid var(--line)}.content h3{font-size:20px;margin:28px 0 10px}.content p{margin:0 0 1em}.quote{border-left:3px solid var(--accent);padding:14px 18px;background:#f4ece3;color:#4e433e}.toc,.note-box,.app-box,.article-notice{padding:18px;margin:22px 0}.app-features{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:16px 0}.app-features span{border:1px solid var(--line);padding:10px;background:#fff;font-size:13px}.sidebar{display:grid;gap:16px;align-content:start}.side-card{padding:18px}.side-card h3{margin:0 0 10px}.side-list{padding-left:1.1em;margin:0}.side-list li{margin:.5em 0}.small,.ad-note,.form-note{font-size:12px;color:var(--muted)}.legal{padding:28px 0 76px;max-width:850px}.legal h2{font-family:Georgia,"Times New Roman","Yu Mincho",YuMincho,serif;font-size:28px;font-weight:500;border-top:1px solid var(--line);padding-top:24px;margin-top:34px}.form{display:grid;gap:18px}.field{display:grid;gap:6px}.field input,.field textarea,.field select{width:100%;border:1px solid var(--line);background:#fff;padding:12px;font:inherit}.required{color:var(--danger);font-size:12px}.ad-note{border-top:1px solid var(--line);padding-top:12px}.visual.article-img{min-height:320px;margin:24px 0;background:#cbb8aa}.btn.btn-white{background:#fff;color:var(--ink)}
@media(max-width:900px){.head{min-height:auto;padding:14px 0;align-items:flex-start;flex-direction:column}.nav{width:100%;overflow-x:auto;gap:14px;padding-bottom:4px}.hero{padding:0 0 48px}.hero-stack{min-height:520px;padding:52px 0 38px}.editorial-layout,.two-columns,.two,.article-layout,.category-grid{grid-template-columns:1fr}.number-list{grid-template-columns:repeat(2,1fr)}.simple-links a{grid-template-columns:1fr;gap:4px}.cards{grid-template-columns:1fr}.article{padding:24px}.sidebar{display:none}.plain-title{display:block}.plain-title p{margin-top:8px}.list-card{grid-template-columns:120px 1fr}.app-features{grid-template-columns:1fr}}
@media(max-width:560px){.wrap{width:min(100% - 28px,1120px)}.age{font-size:11px}.brand{font-size:18px}.nav{font-size:12px}.hero h1{font-size:38px}.lead{font-size:15px}.hero-stack{min-height:440px;padding:42px 0 26px}.actions{display:grid}.btn{width:100%}.section{padding:46px 0}.number-list{grid-template-columns:1fr}.number-list a{min-height:0}.lead-story h2,.text-column h2,.plain-title h2{font-size:28px}.panel{padding:22px}.list-card{display:block}.list-card .thumb{height:140px;margin-bottom:14px}.visual.article-img{min-height:220px}}

/* Experience article: title + body only */
.experience-article{padding:42px 52px 54px}
.experience-article .article-head{border-bottom:1px solid var(--line);padding-bottom:30px;margin-bottom:32px}
.experience-article .article-head h1{font-size:clamp(34px,4.2vw,58px);line-height:1.28;letter-spacing:.015em;margin:18px 0 0}
.experience-article .labelrow{margin-bottom:10px}
.experience-article .content{font-size:17px;line-height:2.05}
.experience-article .content p{margin:0 0 1.35em}
@media(max-width:560px){.experience-article{padding:28px 22px 36px}.experience-article .article-head{padding-bottom:22px;margin-bottom:24px}.experience-article .article-head h1{font-size:32px}.experience-article .content{font-size:16px;line-height:1.95}}

/* Experience app line */
.experience-app-line{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 0;margin:30px 0 22px;display:flex;justify-content:space-between;gap:16px;align-items:center;font-size:14px;color:var(--muted)}.experience-app-line a{color:var(--ink);text-decoration:underline;text-underline-offset:3px}.experience-app-line span{letter-spacing:.02em}@media(max-width:560px){.experience-app-line{display:block}.experience-app-line a{display:inline-block;margin-top:6px}}

/* Minimal app link for experience articles */
.app-mini-line{border-top:1px solid var(--line);margin-top:34px;padding-top:14px;font-size:13px;color:var(--muted);display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.app-mini-line .app-name{color:var(--ink);font-weight:600}
.app-mini-line a{border-bottom:1px solid currentColor;color:var(--accent-dark)}

.compare-scroll{overflow-x:auto;margin:22px 0 30px;border:1px solid var(--line);background:#fff}
.compare-table{width:100%;border-collapse:collapse;min-width:760px;font-size:14px}
.compare-table th,.compare-table td{border-bottom:1px solid var(--line);border-right:1px solid var(--soft-line);padding:14px 12px;vertical-align:top;text-align:left}
.compare-table th{background:#efe7dc;color:var(--ink);font-weight:700}
.compare-table td:first-child{font-weight:700;white-space:nowrap;color:var(--accent-dark)}
.compare-table tr:last-child td{border-bottom:0}
.compare-table th:last-child,.compare-table td:last-child{border-right:0}


/* article cover images */
.article-cover{margin:0 0 30px}
.article-cover img{display:block;width:100%;height:auto;border-radius:18px;object-fit:cover;box-shadow:0 16px 40px rgba(0,0,0,.08)}
.article-cover figcaption{margin-top:10px;font-size:12px;color:var(--muted)}
@media(max-width:560px){.article-cover{margin:0 0 24px}.article-cover img{border-radius:14px}}


/* thumbnail images for article cards and lists */
.thumb img{display:block;width:100%;height:100%;object-fit:cover}
.list-card .thumb{overflow:hidden;border-radius:14px;min-height:170px}
.card .thumb{overflow:hidden;border-radius:14px;min-height:210px}
.experience-card h3{font-size:19px;line-height:1.5}
.experience-card p{line-height:1.7}
.experience-cards{align-items:stretch}
.list-card h3 a{text-decoration:none}


/* app review pages */
.app-review-article .app-box{border:1px solid var(--line);background:#f8f1ea;padding:20px;margin:24px 0}
.app-review-article .app-box h3{margin-top:0}
.app-review-article .app-box .btn{margin-top:8px}
.app-review-article ul{padding-left:1.2em}
.app-review-article li{margin:.45em 0}
