/* SORA Casas · Journal — clean editorial reading style */
:root{
  --paper:#f7f0df; --paper-2:#fcf6e6; --paper-3:#ede4ca;
  --ink:#14110c; --ink-2:#2a251d; --ink-3:#4a4337; --ink-faint:#807761;
  --line:rgba(20,17,12,.10); --line-2:rgba(20,17,12,.18);
  --forest:#1d3a2c; --forest-2:#2a5440; --coral:#d8694a; --gold-deep:#b39656;
  --serif:"Fraunces",Georgia,serif; --sans:"Inter",-apple-system,sans-serif; --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:inherit}
img{max-width:100%;height:auto}

/* top bar */
.top{position:sticky;top:0;z-index:30;background:rgba(247,240,223,.93);backdrop-filter:blur(12px);border-bottom:.5px solid var(--line)}
.top-in{max-width:1080px;margin:0 auto;padding:15px 26px;display:flex;align-items:center;gap:14px}
.top .word{font-family:var(--serif);font-weight:600;font-size:19px;letter-spacing:.04em}
.top .word em{font-style:italic;color:var(--coral)}
.top .sub{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-left:8px}
.top .spacer{flex:1}
.top a.nav{font-size:13px;color:var(--ink-2);text-decoration:none;padding:7px 12px;border-radius:7px}
.top a.nav:hover{background:var(--paper-2)}

/* article shell */
.wrap{max-width:720px;margin:0 auto;padding:0 26px}
.article{padding:56px 0 40px}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--forest);font-weight:600;margin-bottom:18px}
.article h1{font-family:var(--serif);font-weight:400;font-size:clamp(32px,5.5vw,50px);line-height:1.08;letter-spacing:-.02em;color:var(--ink);margin-bottom:20px}
.dek{font-family:var(--serif);font-size:20px;line-height:1.5;color:var(--ink-3);font-style:italic;margin-bottom:26px}
.byline{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--ink-faint);text-transform:uppercase;padding-bottom:26px;border-bottom:.5px solid var(--line-2);margin-bottom:34px}
.byline b{color:var(--ink-2);font-weight:600}
.byline .dot{color:var(--gold-deep)}

/* body type */
.body p{font-size:17.5px;line-height:1.72;color:var(--ink-2);margin:0 0 20px}
.body h2{font-family:var(--serif);font-weight:500;font-size:27px;line-height:1.2;letter-spacing:-.01em;color:var(--ink);margin:46px 0 14px}
.body h3{font-family:var(--serif);font-weight:600;font-size:19px;color:var(--forest);margin:30px 0 8px}
.body strong{font-weight:600;color:var(--ink)}
.body a{color:var(--forest);text-decoration:underline;text-decoration-color:var(--line-2);text-underline-offset:3px}
.body a:hover{text-decoration-color:var(--forest)}
.body ul,.body ol{margin:0 0 20px;padding-left:22px}
.body li{font-size:17.5px;line-height:1.66;color:var(--ink-2);margin-bottom:9px}
.body blockquote{margin:26px 0;padding:4px 0 4px 22px;border-left:3px solid var(--coral);font-family:var(--serif);font-style:italic;font-size:20px;line-height:1.5;color:var(--ink-3)}
.body hr{border:0;border-top:.5px solid var(--line-2);margin:40px 0}
.callout{background:var(--paper-2);border:.5px solid var(--line);border-left:3px solid var(--gold-deep);border-radius:0 10px 10px 0;padding:18px 22px;margin:26px 0}
.callout p{font-size:15.5px;margin:0;color:var(--ink-2)}
.callout .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;margin-bottom:6px}

/* author + end */
.author{display:flex;gap:16px;align-items:flex-start;margin:46px 0 0;padding:24px;background:var(--paper-2);border:.5px solid var(--line);border-radius:12px}
.author .av{width:46px;height:46px;border-radius:50%;background:var(--forest);color:var(--paper);display:grid;place-items:center;font-family:var(--serif);font-size:20px;flex:0 0 auto}
.author .nm{font-weight:600;font-size:15px;color:var(--ink)}
.author .bio{font-size:14px;color:var(--ink-3);line-height:1.55;margin-top:3px}
.endcta{margin:38px 0 0;padding:28px 30px;background:var(--forest);color:var(--paper);border-radius:14px}
.endcta h3{font-family:var(--serif);font-weight:400;font-size:24px;color:var(--paper);margin-bottom:8px}
.endcta p{color:rgba(247,240,223,.82);font-size:15px;margin-bottom:16px}
.endcta a{display:inline-block;background:var(--coral);color:#fff;text-decoration:none;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:11px 20px;border-radius:8px}

/* blog index */
.bloghero{padding:64px 0 30px;border-bottom:.5px solid var(--line)}
.bloghero h1{font-family:var(--serif);font-weight:300;font-size:clamp(40px,7vw,68px);line-height:1;letter-spacing:-.025em;margin-bottom:16px}
.bloghero h1 em{font-style:italic;color:var(--forest)}
.bloghero p{font-family:var(--serif);font-style:italic;font-size:19px;color:var(--ink-3);max-width:560px}
.posts{padding:18px 0 70px}
.post-card{display:block;text-decoration:none;color:inherit;padding:30px 0;border-bottom:.5px solid var(--line);transition:padding-left .18s}
.post-card:hover{padding-left:8px}
.post-card .cat{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--coral);font-weight:600;margin-bottom:9px}
.post-card h2{font-family:var(--serif);font-weight:500;font-size:27px;line-height:1.16;letter-spacing:-.01em;color:var(--ink);margin-bottom:8px}
.post-card p{font-size:15.5px;color:var(--ink-3);line-height:1.55;max-width:600px;margin-bottom:11px}
.post-card .meta{font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--ink-faint);text-transform:uppercase}
.post-card.feat{background:var(--paper-2);border:.5px solid var(--line);border-radius:14px;padding:30px 32px;margin-bottom:14px}
.post-card.feat:hover{padding-left:32px;transform:translateY(-2px);box-shadow:0 12px 34px rgba(20,17,12,.07)}

footer{background:var(--ink);color:rgba(247,240,223,.6);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;text-align:center;padding:32px 20px;margin-top:40px}
footer a{color:var(--gold-deep);text-decoration:none}
@media(max-width:640px){.body p,.body li{font-size:16.5px}}
