/* ==========================================================================
   TRAIN4FUTURE — DESIGN TOKENS
   Palette: warm cream paper + deep ink navy + marigold accent + climbing teal.
   Type: Fraunces (display, warm editorial serif) / Work Sans (body) /
         JetBrains Mono (schedule, labels, numerals — "the program clock").
   Signature: "The Climb" — ascending step motif representing campus-to-corporate.
   ========================================================================== */

:root{
	--ink:        #1B2A44;
	--ink-soft:   #2E3E5C;
	--accent:     #E2963C;   /* marigold — CTA, energy   */
	--accent-2:   #1F6F63;   /* teal — growth, secondary */
	--cream:      #FBF6EC;
	--paper:      #FFFFFF;
	--charcoal:   #33302A;
	--line:       #E4DCC9;
	--line-dark:  rgba(255,255,255,.14);

	--font-display: "Fraunces", Georgia, "Times New Roman", serif;
	--font-body:    "Work Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--font-mono:    "JetBrains Mono", "SFMono-Regular", Menlo, monospace;

	--container: 1180px;
	--radius: 4px;
	--shadow-card: 0 1px 2px rgba(27,42,68,.06), 0 8px 24px -12px rgba(27,42,68,.18);

	--ease: cubic-bezier(.22,.61,.36,1);
}

/* ==========================================================================
   RESET
   ========================================================================== */
*, *::before, *::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
	margin: 0;
	background: var(--cream);
	color: var(--charcoal);
	font-family: var(--font-body);
	font-size: 17px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}
img, svg{ max-width: 100%; display: block; }
a{ color: inherit; text-decoration: none; }
ul, ol{ margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4, blockquote, p{ margin: 0; }
button, input, select{ font-family: inherit; font-size: inherit; color: inherit; }
button{ cursor: pointer; background: none; border: none; }

.screen-reader-text{
	position: absolute; width: 1px; height: 1px; overflow: hidden;
	clip: rect(1px,1px,1px,1px); white-space: nowrap;
}
.skip-link{
	position: fixed; top: -100px; left: 12px; z-index: 999;
	background: var(--ink); color: var(--cream); padding: 10px 18px;
	border-radius: var(--radius); transition: top .2s var(--ease);
}
.skip-link:focus{ top: 12px; width: auto; height: auto; clip: auto; }

:focus-visible{ outline: 3px solid var(--accent-2); outline-offset: 3px; }

.wrap{ max-width: var(--container); margin: 0 auto; padding: 0 24px; }

@media (prefers-reduced-motion: reduce){
	*{ animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
}

/* ==========================================================================
   TYPE
   ========================================================================== */
.eyebrow{
	font-family: var(--font-mono);
	font-size: 12.5px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--accent-2);
	margin: 0 0 14px;
	font-weight: 500;
}
.eyebrow--light{ color: var(--accent); }

.section-title{
	font-family: var(--font-display);
	font-weight: 600;
	font-size: clamp(1.7rem, 1.2rem + 1.8vw, 2.5rem);
	line-height: 1.15;
	color: var(--ink);
	max-width: 18ch;
}
.section-title--light{ color: var(--cream); }

.lede-text{
	font-family: var(--font-display);
	font-size: 1.25rem;
	font-weight: 500;
	line-height: 1.5;
	color: var(--ink);
}

/* ==========================================================================
   BUTTONS
   ========================================================================== */
.btn{
	display: inline-flex; align-items: center; gap: 8px;
	padding: 13px 26px;
	border-radius: 999px;
	font-weight: 600;
	font-size: .95rem;
	transition: transform .18s var(--ease), box-shadow .18s var(--ease), background-color .18s var(--ease), color .18s var(--ease);
	border: 2px solid transparent;
	white-space: nowrap;
}
.btn--accent{ background: var(--accent); color: var(--ink); }
.btn--accent:hover{ background: #cf8530; transform: translateY(-2px); box-shadow: 0 10px 24px -10px rgba(226,150,60,.6); }
.btn--ghost{ border-color: var(--ink); color: var(--ink); }
.btn--ghost:hover{ background: var(--ink); color: var(--cream); transform: translateY(-2px); }
.btn--outline-light{ border-color: rgba(251,246,236,.4); color: var(--cream); }
.btn--outline-light:hover{ background: var(--cream); color: var(--ink); }
.btn--sm{ padding: 9px 18px; font-size: .85rem; }

/* ==========================================================================
   HEADER
   ========================================================================== */
.site-header{
	position: sticky; top: 0; z-index: 60;
	background: rgba(251,246,236,.92);
	backdrop-filter: blur(10px);
	border-bottom: 1px solid var(--line);
}
.site-header__inner{
	display: flex; align-items: center; justify-content: space-between;
	padding: 14px 24px;
	gap: 16px;
}
.brand{ display: flex; align-items: center; gap: 10px; color: var(--ink); }
.brand__mark{ color: var(--accent); flex-shrink: 0; }
.brand__text{ display: flex; flex-direction: column; line-height: 1.1; }
.brand__name{ font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; }
.brand__tag{ font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .04em; color: var(--ink-soft); }

.nav-toggle{ display: none; padding: 6px; z-index: 61; }
.nav-toggle__box{ display: flex; flex-direction: column; gap: 5px; width: 22px; }
.nav-toggle__bar{ height: 2px; background: var(--ink); border-radius: 2px; transition: transform .25s var(--ease), opacity .25s var(--ease); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2){ opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

.site-nav{ display: flex; align-items: center; gap: 28px; }
.nav-menu{ display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.nav-menu a{
	font-size: .92rem; font-weight: 500; color: var(--ink-soft);
	position: relative; padding: 4px 0;
}
.nav-menu a:hover{ color: var(--ink); }
.nav-menu a::after{
	content: ""; position: absolute; left: 0; right: 100%; bottom: 0; height: 2px;
	background: var(--accent); transition: right .25s var(--ease);
}
.nav-menu a:hover::after{ right: 0; }
.nav-cta{ flex-shrink: 0; }

@media (max-width: 900px){
	.nav-toggle{ display: inline-flex; }
	.site-nav{
		position: fixed; inset: 0 0 0 auto; width: min(320px, 84vw); height: 100vh;
		background: var(--ink); color: var(--cream);
		flex-direction: column; align-items: flex-start; justify-content: center;
		gap: 32px; padding: 32px;
		transform: translateX(100%); transition: transform .32s var(--ease);
	}
	.site-nav.is-open{ transform: translateX(0); }
	.nav-menu{ flex-direction: column; align-items: flex-start; gap: 22px; }
	.nav-menu a{ font-size: 1.15rem; color: var(--cream); }
	.nav-menu a::after{ background: var(--accent); }
	.nav-cta{ width: 100%; justify-content: center; }
}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{ padding: 72px 0 56px; overflow: hidden; }
.hero--compact{ padding: 56px 0 32px; }
.hero__inner{ display: grid; grid-template-columns: 1.15fr .85fr; gap: 48px; align-items: center; }
.hero__title{
	font-family: var(--font-display); font-weight: 600;
	font-size: clamp(2.1rem, 1.5rem + 2.6vw, 3.4rem);
	line-height: 1.08; color: var(--ink); max-width: 15ch;
}
.hero__lede{ margin-top: 20px; font-size: 1.08rem; color: var(--ink-soft); max-width: 46ch; }
.hero__actions{ display: flex; gap: 14px; margin-top: 32px; flex-wrap: wrap; }
.hero__steps{ display: flex; flex-direction: column; align-items: center; gap: 10px; }
.steps-svg{ width: 100%; height: auto; }
.hero__steps-label{ font-family: var(--font-mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); }
.hero__steps-label span{ color: var(--accent); }

@media (max-width: 800px){
	.hero__inner{ grid-template-columns: 1fr; gap: 32px; }
	.hero__steps{ order: -1; max-width: 260px; margin: 0 auto; }
}

/* ==========================================================================
   REVEAL-ON-SCROLL
   ========================================================================== */
.reveal{ opacity: 0; transform: translateY(18px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.is-visible{ opacity: 1; transform: translateY(0); }

/* ==========================================================================
   MISSION
   ========================================================================== */
.mission{ padding: 64px 0; }
.mission__inner{ display: grid; grid-template-columns: .8fr 1.2fr; gap: 48px; }
.mission__body p{ margin-bottom: 16px; color: var(--ink-soft); }
.mission__body p:last-child{ margin-bottom: 0; }
@media (max-width: 800px){ .mission__inner{ grid-template-columns: 1fr; gap: 20px; } }

/* ==========================================================================
   CHARACTERISTICS (dark band)
   ========================================================================== */
.characteristics{ background: var(--ink); padding: 72px 0; }
.characteristics .section-title{ margin-bottom: 40px; }
.characteristics__grid{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.characteristic{ border-top: 2px solid var(--line-dark); padding-top: 18px; }
.characteristic__mark{ font-family: var(--font-mono); color: var(--accent); font-size: .85rem; }
.characteristic h3{ font-family: var(--font-display); color: var(--cream); font-size: 1.15rem; margin: 10px 0 8px; }
.characteristic p{ color: rgba(251,246,236,.7); font-size: .92rem; }
@media (max-width: 900px){ .characteristics__grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .characteristics__grid{ grid-template-columns: 1fr; } }

/* ==========================================================================
   KEY SECTIONS / MODULE CARDS
   ========================================================================== */
.key-sections{ padding: 72px 0; }
.key-sections .section-title{ margin-bottom: 36px; }
.key-sections__grid{ display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px; }
.key-sections__grid--plain{ grid-template-columns: repeat(3, 1fr); }
.module-card{
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: 26px 20px;
	position: relative;
	display: flex; flex-direction: column; gap: 10px;
	transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease);
	transform: translateY(calc(var(--i,0) * -2px));
}
.module-card:hover{ transform: translateY(calc(var(--i,0) * -2px) - 4px); box-shadow: var(--shadow-card); border-color: var(--accent); }
.module-card--static{ cursor: default; }
.module-card--static:hover{ transform: translateY(calc(var(--i,0) * -2px)); box-shadow: none; border-color: var(--line); }
.module-card__icon{ color: var(--accent-2); }
.module-card__step{ position: absolute; top: 0; left: 20px; width: 28px; height: 4px; background: var(--accent); border-radius: 0 0 2px 2px; }
.module-card__title{ font-family: var(--font-display); font-size: 1.08rem; color: var(--ink); font-weight: 600; }
.module-card__text{ font-size: .92rem; color: var(--ink-soft); flex-grow: 1; }
.module-card__link{ font-family: var(--font-mono); font-size: .78rem; letter-spacing: .04em; text-transform: uppercase; color: var(--accent-2); }

@media (max-width: 1000px){ .key-sections__grid{ grid-template-columns: repeat(3, 1fr); } .key-sections__grid--plain{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px){ .key-sections__grid, .key-sections__grid--plain{ grid-template-columns: 1fr; } .module-card{ transform: none !important; } }

/* ==========================================================================
   PROMISE / QUOTE
   ========================================================================== */
.promise{ padding: 56px 0; }
.promise__inner{ max-width: 800px; margin: 0 auto; text-align: center; }
.promise__quote{
	font-family: var(--font-display); font-weight: 500; font-style: italic;
	font-size: clamp(1.3rem, 1.05rem + 1vw, 1.8rem); color: var(--ink); line-height: 1.4;
}
.promise__sub{ margin-top: 18px; color: var(--ink-soft); }

/* ==========================================================================
   CTA BAND / REGISTRATION
   ========================================================================== */
.cta-band{ background: var(--ink); color: var(--cream); padding: 76px 0; scroll-margin-top: 90px; }
.cta-band__inner{ display: grid; grid-template-columns: 1fr .95fr; gap: 48px; align-items: start; }
.cta-band__title{ font-family: var(--font-display); font-weight: 600; font-size: clamp(1.6rem, 1.2rem + 1.4vw, 2.2rem); margin: 8px 0 16px; }
.cta-band__sub{ color: rgba(251,246,236,.75); max-width: 44ch; }
.cta-band__facts{ display: flex; gap: 26px; margin-top: 28px; flex-wrap: wrap; }
.cta-band__facts li{ font-size: .82rem; color: rgba(251,246,236,.65); }
.cta-band__fact-num{ display: block; font-family: var(--font-mono); font-size: 1.7rem; color: var(--accent); }

.reg-form{ background: var(--cream); color: var(--charcoal); border-radius: 8px; padding: 30px; display: flex; flex-direction: column; gap: 16px; box-shadow: var(--shadow-card); }
.reg-form__field{ display: flex; flex-direction: column; gap: 6px; font-size: .85rem; font-weight: 600; color: var(--ink); }
.reg-form__field input, .reg-form__field select{
	border: 1.5px solid var(--line); border-radius: var(--radius); padding: 11px 14px;
	background: var(--paper); font-weight: 400; transition: border-color .18s var(--ease);
}
.reg-form__field input:focus, .reg-form__field select:focus{ border-color: var(--accent-2); }
.reg-form__submit{ margin-top: 4px; justify-content: center; }
.reg-form__fine{ font-size: .8rem; color: var(--ink-soft); text-align: center; }
.reg-form__fine a{ color: var(--accent-2); font-weight: 600; }
.reg-form__notice{ font-size: .85rem; padding: 10px 14px; border-radius: var(--radius); }
.reg-form__notice--success{ background: #E4F3EE; color: #17594C; }
.reg-form__notice--error{ background: #FBE6E1; color: #8A2E1D; }

@media (max-width: 860px){ .cta-band__inner{ grid-template-columns: 1fr; } }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{ background: #14213A; color: rgba(251,246,236,.8); padding: 56px 0 0; }
.footer__grid{ display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 36px; padding-bottom: 44px; border-bottom: 1px solid var(--line-dark); }
.footer__brand .brand__mark{ color: var(--accent); }
.footer__name{ font-family: var(--font-display); font-size: 1.2rem; color: var(--cream); margin: 10px 0 10px; font-weight: 700; }
.footer__about{ font-size: .88rem; max-width: 32ch; }
.footer__heading{ font-family: var(--font-mono); font-size: 11.5px; text-transform: uppercase; letter-spacing: .1em; color: var(--accent); margin-bottom: 16px; }
.footer-menu, .footer__nav .nav-menu{ display: flex; flex-direction: column; gap: 11px; }
.footer-menu a, .footer__nav a{ font-size: .9rem; color: rgba(251,246,236,.75); }
.footer-menu a:hover, .footer__nav a:hover{ color: var(--accent); }
.footer__mono{ font-family: var(--font-mono); font-size: .88rem; margin-bottom: 4px; }
.footer__email{ display: inline-block; margin: 10px 0 18px; color: var(--accent); font-weight: 600; font-size: .9rem; }
.footer__bottom{ display: flex; justify-content: space-between; padding: 22px 0; font-size: .8rem; flex-wrap: wrap; gap: 8px; }

/* ==========================================================================
   STICKY MOBILE CTA
   ========================================================================== */
.sticky-cta{
	position: fixed; left: 0; right: 0; bottom: 0; z-index: 55;
	background: var(--ink); color: var(--cream);
	display: none; align-items: center; justify-content: space-between;
	padding: 12px 18px; box-shadow: 0 -8px 24px rgba(0,0,0,.18);
	transform: translateY(100%); transition: transform .3s var(--ease);
}
.sticky-cta.is-visible{ transform: translateY(0); }
.sticky-cta__text{ display: flex; flex-direction: column; font-size: .78rem; line-height: 1.3; }
.sticky-cta__text strong{ font-family: var(--font-display); font-size: .92rem; }
@media (max-width: 700px){ .sticky-cta{ display: flex; } body{ padding-bottom: 64px; } }

/* ==========================================================================
   ABOUT PAGE
   ========================================================================== */
.about-founder{ padding: 20px 0 64px; }
.about-founder__inner{ display: grid; grid-template-columns: .55fr 1.45fr; gap: 48px; align-items: center; }
.portrait-svg{ color: var(--ink); }
.about-founder__text p{ margin-top: 16px; color: var(--ink-soft); }
@media (max-width: 800px){ .about-founder__inner{ grid-template-columns: 1fr; } .about-founder__portrait{ max-width: 180px; margin: 0 auto; } }

.mission-statement{ background: var(--ink); padding: 72px 0; }
.mission-statement .section-title{ margin-bottom: 44px; }
.pillar-list{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px 32px; }
.pillar{ border-top: 2px solid var(--line-dark); padding-top: 16px; position: relative; }
.pillar__step{ position: absolute; top: -2px; left: 0; width: 34px; height: 2px; background: var(--accent); }
.pillar h3{ font-family: var(--font-display); color: var(--cream); font-size: 1.08rem; margin-bottom: 8px; }
.pillar p{ color: rgba(251,246,236,.72); font-size: .9rem; }
@media (max-width: 900px){ .pillar-list{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .pillar-list{ grid-template-columns: 1fr; } }

.mentor-network{ padding: 64px 0; }
.mentor-network__inner{ max-width: 720px; }
.mentor-network__text{ margin: 8px 0 24px; color: var(--ink-soft); font-size: 1.05rem; }

/* ==========================================================================
   JOURNEY / STAIRCASE LIST (Getting Selected, Business Basics)
   ========================================================================== */
.journey{ padding: 64px 0; }
.journey .section-title{ margin-bottom: 40px; }
.journey__list{ display: flex; flex-direction: column; }
.journey__item{
	display: grid; grid-template-columns: 40px 50px 1fr; align-items: center;
	gap: 18px; padding: 16px 0;
	border-bottom: 1px solid var(--line);
	padding-left: calc(var(--i, 0) * 18px);
}
.journey__list--dark .journey__item{ border-bottom-color: var(--line-dark); }
.journey__step-graphic{ display: flex; justify-content: center; }
.journey__step-graphic span{ width: 14px; height: 14px; border-radius: 3px; background: var(--accent); display: block; }
.journey__num{ font-family: var(--font-mono); font-size: .95rem; color: var(--accent-2); }
.journey__list--dark .journey__num{ color: var(--accent); }
.journey__label{ font-family: var(--font-display); font-size: 1.1rem; color: var(--ink); font-weight: 500; }
.journey__list--dark .journey__label{ color: var(--cream); }
.journey--dark{ background: var(--ink); }
@media (max-width: 640px){
	.journey__item{ grid-template-columns: 28px 40px 1fr; padding-left: 0 !important; }
	.journey__label{ font-size: 1rem; }
}

/* ==========================================================================
   SALES PAGE
   ========================================================================== */
.sector-strip{ background: var(--ink); padding: 60px 0; }
.sector-strip .section-title{ margin-bottom: 28px; }
.sector-strip__list{ display: flex; flex-wrap: wrap; gap: 14px; }
.sector-strip__list li{
	font-family: var(--font-mono); font-size: .85rem; letter-spacing: .02em;
	color: var(--cream); border: 1px solid var(--line-dark); border-radius: 999px;
	padding: 10px 20px;
}

/* ==========================================================================
   BUSINESS BASICS PAGE
   ========================================================================== */
.why-matters{ padding: 20px 0 56px; }
.why-matters__inner{ max-width: 760px; }
.tag-section{ padding: 56px 0; }
.tag-section .section-title{ margin-bottom: 32px; }
.tag-grid{ display: flex; flex-wrap: wrap; gap: 14px; }
.tag-grid__item{
	background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
	padding: 14px 20px; font-family: var(--font-display); font-weight: 500; color: var(--ink);
	border-left: 4px solid var(--accent);
}

/* ==========================================================================
   PNP — TWIN ENGINES
   ========================================================================== */
.twin-engines{ padding: 64px 0; }
.twin-engines__grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; }
.engine{ background: var(--paper); padding: 44px 40px; }
.engine--accent{ background: var(--ink); }
.engine--accent .section-title{ color: var(--cream); }
.engine__intro{ margin: 14px 0 28px; color: var(--ink-soft); }
.engine--accent .engine__intro{ color: rgba(251,246,236,.72); }
.engine__list{ display: flex; flex-direction: column; gap: 22px; }
.engine__item{ display: flex; gap: 16px; }
.engine__step{ flex-shrink: 0; width: 10px; height: 10px; border-radius: 50%; background: var(--accent-2); margin-top: 8px; }
.engine__step--light{ background: var(--accent); }
.engine__item h3{ font-family: var(--font-display); font-size: 1.05rem; color: var(--ink); margin-bottom: 4px; }
.engine--accent .engine__item h3{ color: var(--cream); }
.engine__item p{ font-size: .9rem; color: var(--ink-soft); }
.engine--accent .engine__item p{ color: rgba(251,246,236,.68); }
@media (max-width: 800px){ .twin-engines__grid{ grid-template-columns: 1fr; } .engine{ padding: 34px 26px; } }

/* ==========================================================================
   FUTURE TIPS — NUMBERED SECTIONS
   ========================================================================== */
.numbered-sections{ padding: 20px 0 40px; }
.numbered-block{ display: grid; grid-template-columns: 260px 1fr; gap: 32px; padding: 44px 0; border-top: 1px solid var(--line); }
.numbered-block:last-child{ border-bottom: 1px solid var(--line); }
.numbered-block__head{ display: flex; flex-direction: column; gap: 8px; }
.numbered-block__num{ font-family: var(--font-mono); font-size: 2.6rem; color: var(--line); line-height: 1; }
.numbered-block--alt .numbered-block__num{ color: #EAD9BE; }
.numbered-block__head h2{ font-family: var(--font-display); font-size: 1.35rem; color: var(--ink); font-weight: 600; }
.numbered-block__items{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; align-content: start; }
.numbered-block__item{ position: relative; padding-left: 18px; }
.numbered-block__step{ position: absolute; left: 0; top: 6px; width: 8px; height: 8px; background: var(--accent-2); border-radius: 2px; }
.numbered-block__item h3{ font-family: var(--font-display); font-size: 1rem; color: var(--ink); margin-bottom: 6px; font-weight: 600; }
.numbered-block__item p{ font-size: .88rem; color: var(--ink-soft); }
@media (max-width: 900px){
	.numbered-block{ grid-template-columns: 1fr; gap: 18px; }
	.numbered-block__items{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px){ .numbered-block__items{ grid-template-columns: 1fr; } }

/* ==========================================================================
   GENERIC PAGE / BLOG
   ========================================================================== */
.generic-content{ padding: 20px 0 64px; }
.generic-content__inner{ max-width: 760px; }
.generic-content__inner > *{ margin-bottom: 18px; }
.post-list{ display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.post-card{ background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 22px; }
.post-card__thumb{ display: block; margin-bottom: 14px; border-radius: var(--radius); overflow: hidden; }
.post-card__title{ font-family: var(--font-display); font-size: 1.2rem; margin-bottom: 8px; }
.post-card__excerpt{ color: var(--ink-soft); font-size: .92rem; margin-bottom: 10px; }
.post-card__link{ font-family: var(--font-mono); font-size: .8rem; color: var(--accent-2); text-transform: uppercase; }
.pagination{ margin-top: 32px; }
@media (max-width: 700px){ .post-list{ grid-template-columns: 1fr; } }

/* ==========================================================================
   WIDGETS
   ========================================================================== */
.widget-title{ font-family: var(--font-mono); font-size: 11.5px; text-transform: uppercase; letter-spacing: .1em; color: var(--accent); margin-bottom: 14px; }
.widget{ font-size: .88rem; }
.widget ul{ display: flex; flex-direction: column; gap: 8px; }
