
:root {
  --bg: #ffffff;
  --surface: #f9f9f7;
  --surface-warm: #fff4ed;
  --surface-green: #f0f8f3;
  --surface-blue: #f0f7ff;
  --text: #111111;
  --muted: #555555;
  --accent: #ff6b00;
  --accent-dark: #d85600;
  --green: #3fa66b;
  --blue: #4b8fcb;
  --border: #e5e5e1;
  --shadow: 0 28px 70px rgba(17, 17, 17, 0.08);
  --radius: 22px;
  --max: 1160px;
  --content: 760px;
}
* { box-sizing: border-box; -webkit-font-smoothing: antialiased; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 82% 0%, rgba(255, 107, 0, 0.08), transparent 28%),
    radial-gradient(circle at 4% 12%, rgba(63, 166, 107, 0.08), transparent 24%),
    var(--bg);
  line-height: 1.6;
}
h1, h2, h3, .logo { font-family: "Outfit", system-ui, sans-serif; font-weight: 800; letter-spacing: -0.018em; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.container { width: min(var(--max), calc(100% - 56px)); margin: 0 auto; }
.topbar {
  position: sticky; top: 0; z-index: 20;
  background: rgba(255, 255, 255, 0.82);
  border-bottom: 1px solid rgba(229, 229, 225, 0.72);
  backdrop-filter: blur(18px);
}
.nav { display: flex; align-items: center; justify-content: space-between; padding: 28px 0; gap: 24px; }
.logo { font-size: 1.55rem; color: var(--text); line-height: 1; }
.logo span { color: var(--accent); }
.nav-links { display: flex; align-items: center; gap: 28px; font-size: 0.92rem; font-weight: 700; color: var(--muted); }
.nav-links a:hover { color: var(--text); }
.nav-pill { padding: 10px 16px; border-radius: 999px; background: var(--text); color: #ffffff; }
.kicker {
  display: inline-flex; align-items: center; gap: 9px;
  text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--accent); font-size: 0.76rem; font-weight: 800; margin-bottom: 22px;
}
.kicker::before { content: ""; width: 8px; height: 8px; border-radius: 999px; background: var(--accent); }
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  background: var(--text); color: #ffffff; padding: 14px 20px; border-radius: 8px;
  font-weight: 800; font-size: 0.95rem; transition: 0.2s ease;
  border: 1px solid var(--text); margin-top: 20px;
}
.btn:hover { background: var(--accent); border-color: var(--accent); transform: translateY(-2px); }
.btn-light { background: #ffffff; color: var(--text); border-color: var(--border); }
.btn-light:hover { color: #ffffff; }
.hero { padding: 92px 0 64px; border-bottom: 1px solid var(--border); }
.hero-layout { display: grid; grid-template-columns: minmax(0, 1fr) 380px; gap: 56px; align-items: end; }
.hero h1 { font-size: clamp(3rem, 7vw, 5.6rem); line-height: 1.04; margin: 0 0 28px; max-width: 980px; }
.hero h1 em { color: var(--accent); font-style: normal; }
.hero p { font-size: clamp(1.12rem, 2vw, 1.34rem); color: var(--muted); max-width: 780px; margin: 0; line-height: 1.72; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; margin-top: 12px; }
.hero-card {
  background: var(--surface-warm); border: 1px solid rgba(255, 107, 0, 0.28);
  border-radius: var(--radius); padding: 28px; box-shadow: var(--shadow);
}
.hero-card .label { color: var(--accent); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.14em; font-weight: 800; margin-bottom: 18px; }
.hero-card p { margin: 0; color: var(--text); font-size: 1.25rem; font-family: "Outfit", system-ui, sans-serif; font-weight: 800; line-height: 1.42; letter-spacing: -0.01em; }
.hero-card small { display: block; margin-top: 18px; color: var(--muted); font-size: 0.93rem; line-height: 1.55; }

.section { padding: 88px 0; }
.section-heading { display: grid; grid-template-columns: minmax(0, 1fr) 420px; gap: 42px; align-items: end; padding-bottom: 34px; border-bottom: 1px solid var(--border); margin-bottom: 0; }
.section h2 { font-size: clamp(2.35rem, 5vw, 4.7rem); line-height: 1.06; margin: 0; max-width: 780px; }
.section-intro { color: var(--muted); font-size: 1.06rem; margin: 0; }
.bento-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 1px; background: var(--border); border-bottom: 1px solid var(--border); }
.bento-card { background: var(--bg); min-height: 310px; padding: 56px; position: relative; overflow: hidden; transition: 0.25s ease; }
.bento-card:hover { background: var(--surface); }
.bento-card.large { grid-column: span 7; min-height: 430px; }
.bento-card.medium { grid-column: span 5; min-height: 430px; }
.bento-card.third { grid-column: span 4; }
.bento-card.half { grid-column: span 6; }
.bento-card.full { grid-column: span 12; }
.bento-card.warm { background: var(--surface-warm); }
.bento-card.green { background: var(--surface-green); }
.bento-card.blue { background: var(--surface-blue); }
.num { display: block; color: var(--accent); font-weight: 800; font-size: 0.92rem; margin-bottom: 24px; opacity: 0.72; letter-spacing: 0.12em; }
.bento-card h3 { font-size: clamp(1.75rem, 3vw, 2.55rem); line-height: 1.18; margin: 0 0 18px; max-width: 520px; }
.bento-card p { color: var(--muted); font-size: 1.05rem; margin: 0; max-width: 590px; line-height: 1.74; }
.mini-list { list-style: none; padding: 0; margin: 28px 0 0; display: grid; gap: 10px; }
.mini-list li { display: flex; align-items: center; gap: 10px; color: var(--text); font-weight: 700; font-size: 0.94rem; }
.mini-list li::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--accent); flex: 0 0 auto; }

.roadmap { counter-reset: road; display: grid; gap: 1px; background: var(--border); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.roadmap-step { background: var(--bg); padding: 36px 42px; display: grid; grid-template-columns: 120px minmax(0, 1fr) 160px; gap: 28px; align-items: center; }
.roadmap-step strong { color: var(--accent); font-family: "Outfit", system-ui, sans-serif; font-size: 1.1rem; letter-spacing: 0.08em; }
.roadmap-step h3 { margin: 0 0 8px; font-size: 1.55rem; line-height: 1.1; }
.roadmap-step p { margin: 0; color: var(--muted); line-height: 1.7; }
.roadmap-tag { justify-self: end; display: inline-flex; align-items: center; justify-content: center; min-width: 112px; padding: 10px 16px; border: 1px solid rgba(255, 107, 0, 0.22); border-radius: 999px; color: var(--accent-dark); font-size: 0.88rem; font-weight: 800; background: var(--surface-warm); text-align: center; }
.roadmap-step:nth-child(2) .roadmap-tag { color: #277247; border-color: rgba(63, 166, 107, 0.24); background: var(--surface-green); }
.roadmap-step:nth-child(3) .roadmap-tag { color: #2e6b9b; border-color: rgba(75, 143, 203, 0.24); background: var(--surface-blue); }
.roadmap-step:nth-child(4) .roadmap-tag { color: var(--text); border-color: rgba(17, 17, 17, 0.14); background: var(--surface); }

.story-card { display: grid; grid-template-columns: minmax(0, 0.95fr) minmax(340px, 0.72fr); gap: 54px; align-items: stretch; padding: 64px; background: var(--text); color: #ffffff; border-radius: var(--radius); box-shadow: var(--shadow); }
.story-copy { display: flex; flex-direction: column; justify-content: space-between; gap: 28px; }
.story-copy-main { max-width: 640px; }
.story-card .kicker { color: var(--accent); }
.story-card h2 { color: #ffffff; font-size: clamp(2.6rem, 5.8vw, 5.2rem); line-height: 1.03; max-width: 640px; margin-bottom: 24px; }
.story-card p { color: rgba(255, 255, 255, 0.76); font-size: 1.08rem; line-height: 1.72; margin: 0 0 18px; }
.quote-box { background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.14); padding: 34px; border-radius: var(--radius); display: flex; align-items: center; min-height: 100%; }
.quote-box p { font-family: "Outfit", system-ui, sans-serif; font-size: clamp(1.45rem, 2.4vw, 2rem); line-height: 1.34; font-weight: 800; color: #ffffff; letter-spacing: -0.01em; margin: 0; }
.story-actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.story-note { color: rgba(255, 255, 255, 0.52); font-size: 0.92rem; font-weight: 700; }

.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border); border-bottom: 1px solid var(--border); }
.post-card { background: var(--bg); padding: 46px; min-height: 320px; display: flex; flex-direction: column; transition: 0.25s ease; }
.post-card:hover { background: var(--surface); }
.post-meta { color: var(--accent); font-size: 0.76rem; text-transform: uppercase; letter-spacing: 0.14em; font-weight: 800; margin-bottom: 22px; }
.post-card h3 { font-size: 1.65rem; line-height: 1.22; margin: 0 0 18px; }
.post-card p { margin: 0 0 24px; color: var(--muted); }
.read-link { margin-top: auto; color: var(--text); font-weight: 800; border-bottom: 2px solid var(--accent); width: fit-content; }

.cta { padding: 68px; border-radius: var(--radius); background: radial-gradient(circle at top right, rgba(255, 107, 0, 0.16), transparent 38%), var(--surface-warm); border: 1px solid rgba(255, 107, 0, 0.25); display: grid; grid-template-columns: 1fr auto; gap: 36px; align-items: center; }
.cta h2 { margin: 0 0 18px; font-size: clamp(2.3rem, 5vw, 4.7rem); line-height: 1.06; }
.cta p { margin: 0; color: var(--muted); font-size: 1.08rem; max-width: 720px; line-height: 1.72; }

.blog-wrap { padding: 70px 0 92px; }
.blog-layout { display: block; max-width: 980px; margin: 0 auto; }
.post-list { display: grid; gap: 1px; background: var(--border); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.blog-list-card { background: var(--bg); padding: 42px; display: grid; grid-template-columns: 150px minmax(0, 1fr); gap: 32px; transition: 0.22s ease; }
.blog-list-card:hover { background: var(--surface); }
.date-box { display: flex; flex-direction: column; gap: 10px; align-items: flex-start; }
.date { color: var(--accent); font-weight: 800; text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.82rem; line-height: 1.4; }
.category { display: inline-flex; align-items: center; justify-content: center; min-width: 112px; padding: 9px 13px; border-radius: 999px; font-size: 0.82rem; font-weight: 800; border: 1px solid rgba(255, 107, 0, 0.22); background: var(--surface-warm); color: var(--accent-dark); }
.category.habits { color: #277247; border-color: rgba(63, 166, 107, 0.24); background: var(--surface-green); }
.blog-list-card h2 { font-size: clamp(1.8rem, 3.2vw, 2.7rem); line-height: 1.13; margin: 0 0 16px; max-width: 780px; }
.blog-list-card p { margin: 0 0 24px; color: var(--muted); line-height: 1.76; font-size: 1.04rem; max-width: 780px; }

.article-hero { padding: 86px 0 44px; border-bottom: 1px solid var(--border); }
.article-labels { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; margin-bottom: 24px; }
.article-hero h1 { font-size: clamp(2.65rem, 5.2vw, 4.7rem); line-height: 1.08; margin: 0 0 24px; max-width: 920px; }
.article-hero p { font-size: clamp(1.1rem, 2vw, 1.32rem); color: var(--muted); max-width: 780px; margin: 0; line-height: 1.72; }
.meta-row { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; color: var(--muted); font-size: 0.96rem; font-weight: 700; margin-top: 28px; }
.meta-row span:not(:last-child)::after { content: ""; display: inline-block; width: 5px; height: 5px; margin-left: 14px; border-radius: 999px; background: var(--accent); vertical-align: middle; }
.side-image { margin: 0; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border); background: var(--surface-warm); box-shadow: 0 18px 50px rgba(17, 17, 17, 0.045); }
.side-image img { width: 100%; height: 190px; object-fit: cover; object-position: center; }
.side-image figcaption { padding: 14px 16px 16px; color: var(--muted); font-size: 0.88rem; line-height: 1.55; }
.article-wrap { padding: 72px 0 90px; }
.article-layout, .about-layout { display: grid; grid-template-columns: minmax(0, var(--content)) 280px; gap: 72px; align-items: start; justify-content: center; }
.article-content, .content { font-size: 1.08rem; color: #222222; }
.article-content p, .content p { margin: 0 0 24px; line-height: 1.82; }
.article-content h2, .content h2 { font-size: clamp(2rem, 3.5vw, 3rem); line-height: 1.12; margin: 58px 0 18px; }
.article-content a, .content a { color: var(--accent-dark); font-weight: 800; border-bottom: 2px solid rgba(255, 107, 0, 0.28); }
.article-content ul { margin: 0 0 28px; padding-left: 0; list-style: none; display: grid; gap: 10px; }
.article-content li { position: relative; padding-left: 24px; color: var(--text); font-weight: 600; }
.article-content li::before { content: ""; position: absolute; left: 0; top: 0.72em; width: 7px; height: 7px; border-radius: 999px; background: var(--accent); }
.pull-quote { margin: 44px 0; padding: 34px; background: var(--text); color: #ffffff; border-radius: var(--radius); box-shadow: var(--shadow); }
.pull-quote p { font-family: "Outfit", system-ui, sans-serif; font-size: clamp(1.7rem, 3vw, 2.4rem); font-weight: 800; line-height: 1.25; margin: 0; letter-spacing: -0.01em; }
.simple-list { margin: 34px 0; display: grid; gap: 1px; background: var(--border); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.simple-list div { background: var(--bg); padding: 20px 24px; font-weight: 800; display: flex; align-items: center; gap: 12px; }
.simple-list div::before { content: ""; width: 8px; height: 8px; border-radius: 999px; background: var(--accent); flex: 0 0 auto; }
.sidebar { position: sticky; top: 118px; display: grid; gap: 18px; }
.side-card { border: 1px solid var(--border); background: #ffffff; border-radius: var(--radius); padding: 24px; box-shadow: 0 18px 50px rgba(17, 17, 17, 0.045); }
.side-card.warm { background: var(--surface-warm); border-color: rgba(255, 107, 0, 0.24); }
.side-card.green { background: var(--surface-green); border-color: rgba(63, 166, 107, 0.24); }
.side-card h3 { font-size: 1.3rem; line-height: 1.18; margin: 0 0 12px; }
.side-card p { margin: 0; color: var(--muted); line-height: 1.68; font-size: 0.96rem; }
.next-posts { margin-top: 70px; border-top: 1px solid var(--border); padding-top: 36px; }
.next-posts h2 { font-size: 2rem; margin: 0 0 18px; }
.next-links { display: grid; gap: 1px; background: var(--border); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.next-links a { background: var(--bg); padding: 20px; font-weight: 800; color: var(--text); border-bottom: 0; }
.next-links a:hover { background: var(--surface); }

.principles { display: grid; gap: 1px; background: var(--border); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin: 38px 0 0; }
.principle { background: var(--bg); padding: 24px; }
.principle strong { display: block; font-family: "Outfit", system-ui, sans-serif; font-size: 1.35rem; line-height: 1.15; margin-bottom: 8px; }
.principle p { margin: 0; color: var(--muted); line-height: 1.68; }

.contact-card { margin-top: 42px; background: var(--surface-warm); border: 1px solid rgba(255, 107, 0, 0.24); border-radius: var(--radius); padding: 34px; box-shadow: var(--shadow); }
.contact-card a { color: var(--accent-dark); font-weight: 800; border-bottom: 2px solid rgba(255, 107, 0, 0.28); }

footer { padding: 54px 0; border-top: 1px solid var(--border); color: var(--muted); font-size: 0.9rem; }
.footer-inner { display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.footer-links { display: flex; gap: 20px; flex-wrap: wrap; }
.footer-links a:hover { color: var(--text); }

@media (max-width: 980px) {
  .hero-layout, .section-heading, .story-card, .cta { grid-template-columns: 1fr; }
  .hero-card { max-width: 620px; }
  .bento-card.large, .bento-card.medium, .bento-card.third, .bento-card.half { grid-column: span 12; }
  .blog-grid { grid-template-columns: 1fr; }
  .roadmap-step { grid-template-columns: 1fr; gap: 12px; }
  .roadmap-tag { justify-self: start; }
  .article-layout, .about-layout { grid-template-columns: 1fr; gap: 46px; }
  .sidebar { position: static; grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .container { width: min(var(--max), calc(100% - 32px)); }
  .nav-links { display: none; }
  .hero, .article-hero { padding: 62px 0 42px; }
  .hero h1 { font-size: 2.9rem; }
  .article-hero h1 { font-size: 2.55rem; }
  .bento-card, .post-card, .blog-list-card, .roadmap-step, .story-card, .cta { padding: 32px; }
  .story-card { border-radius: 0; margin-left: -16px; margin-right: -16px; }
  .sidebar { grid-template-columns: 1fr; }
  .blog-list-card { grid-template-columns: 1fr; }
}
