/* =============================================================
   RESPONSIVE CSS — All @media queries
   Mobile (390–768px) + Tablet (1024px) + Wide (1440–2200px+)
   ============================================================= */

/* --- 1024px: Tablet --- */
@media (max-width: 1024px) {
  .dg { grid-template-columns: 130px 1fr; }
  .dgr { grid-template-columns: 1fr 130px; }
  .bg { grid-template-columns: repeat(2, 1fr) !important; gap: 24px !important; }
  .bf-featured { grid-column: span 2 !important; }
  .portfolio-grid { padding: 0 40px 60px; gap: 16px; }
}

/* =============================================
   WIDE SCREEN DESIGN PASS
   Studio Display (2560×1440 CSS), Pro Display XDR,
   Ultra-wide, 4K scaled — cinematic, expansive, premium
   ============================================= */

/* --- 1440px: Large laptop / external monitor --- */
@media (min-width: 1440px) {
  .dg, .dgr { max-width: 1320px; }
  .hp { max-width: 1320px !important; }
  .crew-inner { max-width: 1320px !important; }
  .cah-interlude, .cah-closing { max-width: 1200px !important; }
  .footer-inner { max-width: 1320px !important; }
  .footer-redesign { max-width: 1320px; padding: 140px 64px 100px; }
  .footer-signup { max-width: 600px; }
  .footer-legal { max-width: 680px; }
  .footer-meta-item { padding: 32px 28px; }
  .traj-outer { max-width: 1320px !important; }

  .dg { grid-template-columns: 180px 1fr; }
  .dgr { grid-template-columns: 1fr 180px; }
  .gut { padding: 56px 32px 56px 0; }
  .gutr { padding: 56px 0 56px 32px; }
  .db { padding: 56px 0 56px 56px; }
  .dbl { padding: 56px 56px 56px 0; }

  .sp { padding: 220px 64px !important; }
  .dark-section { padding: 220px 64px !important; }

  .prose { font-size: 17px; line-height: 1.6; max-width: 680px; }
  .ds { letter-spacing: -.035em; }

  .cahg { gap: 28px !important; }
  .card-hand.triple { gap: 28px !important; }
  .cg { gap: 48px !important; }
  .cc, .cw { padding: 36px 32px 52px; border-radius: 10px; }
  .cah-opening, .cah-closing { max-width: 560px !important; }
  .cah-play-area { gap: 36px; }

  .traj-svg { max-width: 700px !important; }
  .moon-hero { height: clamp(380px, 35vw, 560px) !important; }
  .signup-section { max-width: 620px; }
}

/* --- 1680px: Large desktop --- */
@media (min-width: 1680px) {
  .dg, .dgr { max-width: 1480px; }
  .hp { max-width: 1480px !important; }
  .crew-inner { max-width: 1480px !important; }
  .cah-interlude, .cah-closing { max-width: 1320px !important; }
  .footer-inner { max-width: 1480px !important; }
  .footer-redesign { max-width: 1480px; padding: 160px 72px 120px; }
  .traj-outer { max-width: 1480px !important; }

  .dg { grid-template-columns: 200px 1fr; }
  .dgr { grid-template-columns: 1fr 200px; }
  .gut { padding: 64px 36px 64px 0; font-size: 13px; }
  .gutr { padding: 64px 0 64px 36px; font-size: 13px; }
  .db { padding: 64px 0 64px 64px; }
  .dbl { padding: 64px 64px 64px 0; }

  .sp { padding: 260px 72px !important; }
  .dark-section { padding: 260px 72px !important; }
  .hp { padding: 120px 72px 100px !important; }
  .footer-inner { padding: 140px 72px !important; }
  .footer-meta-value { font-size: 13px; }
  .footer-legal p { font-size: 14px; }

  .prose { font-size: 18px; line-height: 1.65; max-width: 720px; }
  h1.ds { font-size: clamp(48px, 5vw, 76px) !important; }
  h2.ds { font-size: clamp(28px, 3vw, 40px) !important; }
  .sn[data-count] { font-size: clamp(44px, 5vw, 72px) !important; }

  .cah-opening, .cah-closing { max-width: 580px !important; }
  .cc p, .cw p { font-size: 18px !important; }
  .cah-play-area { gap: 40px; }
  .cahg { gap: 32px !important; }
  .card-hand.triple { gap: 32px !important; }
  .cg { gap: 56px !important; }

  .traj-svg { max-width: 800px !important; }
  .moon-hero { height: clamp(420px, 32vw, 640px) !important; }
  .assess-box { max-width: 880px !important; padding: 72px 64px 60px !important; }

  .signup-section { max-width: 660px; }
  .signup-input { font-size: 15px; padding: 14px 20px; }
  .signup-btn { padding: 14px 28px; }

  .mt { font-size: 13px; }
  .mt td { padding: 14px 12px; }
  .mnote { font-size: 15px; }
  .gr { margin: 72px 0 !important; }
  .fact-card { padding: 32px 36px !important; }
  .fact-card .prose { font-size: 17px; }
  .sc { padding: 28px; }
  .s2 { gap: 28px !important; }
  .stamp { font-size: 15px; padding: 6px 14px; }
}

/* --- 1920px: Full HD+ / Cinema --- */
@media (min-width: 1920px) {
  .dg, .dgr { max-width: 1600px; }
  .hp { max-width: 1600px !important; }
  .crew-inner { max-width: 1600px !important; }
  .cah-interlude, .cah-closing { max-width: 1440px !important; }
  .footer-inner { max-width: 1600px !important; }
  .footer-redesign { max-width: 1600px; padding: 180px 80px 140px; }
  .footer-signup { max-width: 640px; }
  .footer-legal { max-width: 720px; }
  .traj-outer { max-width: 1600px !important; }

  .dg { grid-template-columns: 220px 1fr; }
  .dgr { grid-template-columns: 1fr 220px; }
  .gut, .gutr { font-size: 13px; letter-spacing: .1em; }
  .gut { padding: 72px 40px 72px 0; }
  .gutr { padding: 72px 0 72px 40px; }
  .db { padding: 72px 0 72px 72px; }
  .dbl { padding: 72px 72px 72px 0; }

  .sp { padding: 300px 80px !important; }
  .dark-section { padding: 300px 80px !important; }
  .hp { padding: 140px 80px 120px !important; }
  .footer-inner { padding: 160px 80px !important; }

  .prose { font-size: 19px; line-height: 1.65; max-width: 760px; }
  h1.ds { font-size: clamp(56px, 5vw, 84px) !important; }
  h2.ds { font-size: clamp(32px, 3vw, 44px) !important; }
  .sn[data-count] { font-size: clamp(52px, 5vw, 80px) !important; }

  .cc, .cw { padding: 40px 36px 56px; border-radius: 12px; }
  .cc p, .cw p { font-size: 19px !important; line-height: 1.5 !important; }
  .cah-opening, .cah-closing { max-width: 600px !important; }
  .cah-play-area { gap: 44px; }
  .cahg { gap: 36px !important; }
  .card-hand.triple { gap: 36px !important; }
  .cg { gap: 64px !important; }
  .cg { grid-template-columns: repeat(4, 1fr) !important; }
  .cp { aspect-ratio: 3/4; }

  .traj-svg { max-width: 900px !important; }
  .moon-hero { height: clamp(480px, 30vw, 720px) !important; }
  .assess-box { max-width: 960px !important; padding: 80px 72px 68px !important; }
  .assess-box p:first-of-type { font-size: 22px !important; }
  .assess-box p { font-size: 18px !important; }

  .signup-section { max-width: 700px; }
  .fi { font-size: 15px; }
  .fb { margin-top: 44px; padding-top: 28px; }
  .hl { font-size: 13px; letter-spacing: .1em; }
  .dl { font-size: 13px; letter-spacing: .14em; }

  .mt { font-size: 14px; }
  .mt td { padding: 16px 14px; }
  .mt th { font-size: 13px; }
  .mtime { font-size: 13px; }
  .mnote { font-size: 16px; }
  .pb { font-size: 13px; padding: 4px 9px; }
  .sh { font-size: 13px; letter-spacing: .18em; }
  .obj-list li { font-size: 15px !important; padding: 9px 0 !important; }
  .stamp { font-size: 16px; padding: 7px 16px; }
  .tape { font-size: 13px; letter-spacing: .3em; }
}

/* --- 2200px+: Apple Studio Display / Ultra-wide --- */
@media (min-width: 2200px) {
  .dg, .dgr { max-width: 1800px; }
  .hp { max-width: 1800px !important; }
  .crew-inner { max-width: 1800px !important; }
  .cah-interlude, .cah-closing { max-width: 1600px !important; }
  .footer-inner { max-width: 1800px !important; }
  .footer-redesign { max-width: 1800px; padding: 220px 96px 160px; }
  .footer-signup { max-width: 700px; }
  .footer-legal { max-width: 760px; }
  .footer-meta-item { padding: 36px 32px; }
  .footer-meta-label { font-size: 11px; }
  .footer-meta-value { font-size: 14px; }
  .footer-legal p { font-size: 15px; }
  .footer-endmark-rule { font-size: 12px; }
  .footer-endmark-copy { font-size: 12px; }
  .traj-outer { max-width: 1800px !important; }

  .dg { grid-template-columns: 260px 1fr; }
  .dgr { grid-template-columns: 1fr 260px; }
  .gut { padding: 80px 48px 80px 0; font-size: 14px; }
  .gutr { padding: 80px 0 80px 48px; font-size: 14px; }
  .db { padding: 80px 0 80px 80px; }
  .dbl { padding: 80px 80px 80px 0; }
  .gl { font-size: inherit; letter-spacing: .14em; }

  .sp { padding: 360px 96px !important; }
  .dark-section { padding: 360px 96px !important; }
  .hp { padding: 180px 96px 160px !important; }
  .footer-inner { padding: 200px 96px !important; }

  .prose { font-size: 20px; line-height: 1.7; max-width: 800px; }
  h1.ds { font-size: clamp(64px, 4.5vw, 96px) !important; }
  h2.ds { font-size: clamp(36px, 2.8vw, 52px) !important; }
  .sn[data-count] { font-size: clamp(60px, 5vw, 92px) !important; }

  .cc, .cw { padding: 44px 40px 60px; border-radius: 14px; }
  .cah-opening, .cah-closing { max-width: 660px !important; }
  .cah-play-area { gap: 48px; }
  .cc p, .cw p { font-size: 20px !important; }
  .clb { font-size: 12px; }
  .cl { font-size: 12px; }
  .cah-opening { max-width: 640px !important; }
  .cahg { gap: 40px !important; }
  .card-hand.triple { gap: 40px !important; }
  .cg { gap: 72px !important; }
  .crew-card-body { padding: 28px 32px 36px !important; }

  .traj-svg { max-width: 1000px !important; }
  .moon-hero { height: clamp(560px, 28vw, 800px) !important; }
  .moon-cap p { font-size: 13px !important; }
  .assess-box { max-width: 1080px !important; padding: 96px 88px 80px !important; }
  .assess-box p:first-of-type { font-size: 24px !important; }
  .assess-box p { font-size: 19px !important; }

  .signup-section { max-width: 760px; }
  .signup-input { font-size: 16px; padding: 16px 24px; }
  .signup-btn { padding: 16px 32px; font-size: 13px; }

  .mt { font-size: 15px; }
  .mt td { padding: 18px 16px; }
  .mt th { font-size: 14px; letter-spacing: .14em; }
  .mtime { font-size: 14px; }
  .mnote { font-size: 17px; }
  .pb { font-size: 14px; padding: 5px 10px; border-radius: 3px; }

  .fact-card { padding: 36px 42px !important; border-radius: 2px; }
  .fact-card .prose { font-size: 19px; }
  .sc { padding: 32px; border-radius: 2px; }
  .sc ul { font-size: 16px !important; line-height: 1.65 !important; }
  .s2 { gap: 32px !important; }

  .note-box { padding: 24px 32px !important; }
  .cost-box { padding: 28px 36px !important; }
  .note-box p, .cost-box p { font-size: 16px !important; }

  .hl { font-size: 14px; letter-spacing: .1em; line-height: 1.7; }
  .dl { font-size: 14px; }
  .cb { font-size: 13px; padding: 4px 10px; }
  .sh { font-size: 14px; letter-spacing: .2em; padding-bottom: 8px; }
  .sh::after { height: 2px; }
  .stamp { font-size: 17px; padding: 8px 18px; border-width: 4px; }
  .tape { font-size: 14px; letter-spacing: .35em; }
  .gr { margin: 88px 0 !important; }
  .fi { font-size: 16px; line-height: 1.75; }
  .fb { margin-top: 52px; padding-top: 32px; }
  .ff { gap: 72px !important; }
}

/* =============================================
   MOBILE DESIGN PASS
   Intentional pacing. Palm-native. Premium.
   ============================================= */

@media (max-width: 768px) {
  .dg, .dgr { grid-template-columns: 1fr; }
  .sg { grid-template-columns: 1fr !important; gap: 24px !important; }
  .cg { grid-template-columns: 1fr !important; gap: 24px !important; }
  .cahg { grid-template-columns: 1fr !important; gap: 20px !important; }
  .card-hand.triple { grid-template-columns: 1fr !important; gap: 20px !important; }
  .s2 { grid-template-columns: 1fr !important; }
  .bg { grid-template-columns: 1fr !important; gap: 16px !important; }
  .bf-featured { grid-column: span 1 !important; }
  .portfolio-grid { grid-template-columns: 1fr; padding: 0 28px 48px; gap: 32px; }
  .portfolio-card-full { grid-column: auto; }
  .portfolio-card-full .portfolio-card-img { aspect-ratio: 16/10; }
  .portfolio-card-title { font-size: 14px; }
  .portfolio-card-type { font-size: 10px; }

  .hf { flex-direction: column; align-items: flex-start !important; }
  .hs { align-items: flex-start !important; flex-direction: row; }
  .hhr { text-align: left !important; }

  .sp { padding: 72px 28px !important; }
  .hp { padding: 52px 28px !important; }
  .dark-section { padding: 64px 24px !important; }
  .crew-inner { padding: 0 24px !important; }
  .assess-box { padding: 32px 24px 28px !important; }
  .moon-cap { padding: 14px 20px !important; }
  .footer-inner { padding: 64px 28px !important; }
  .footer-redesign { padding: 72px 28px 56px !important; }
  .footer-meta { grid-template-columns: 1fr 1fr; }
  .footer-meta-item:nth-child(2) { border-right: none; }
  .footer-meta-item:last-child { grid-column: 1 / -1; border-right: none; border-top: 1px solid rgba(0,0,0,.06); }
  .footer-legal { padding-top: 36px; }
  .footer-legal p { font-size: 12px; }
  .footer-endmark { padding-top: 40px; }
  .footer-signup h2 { font-size: clamp(18px, 4vw, 24px) !important; }
  .ff { flex-direction: column; align-items: flex-start !important; }
  .fr { text-align: left !important; }

  .nasa-worm { height: 56px !important; margin: 32px 0 40px !important; }
  .patch-wrap { display: flex; justify-content: center; width: 100%; }
  .sg > div { text-align: center; }
  .cp { aspect-ratio: 4/5; }

  .cc .cl, .cw .cl { bottom: 12px; right: 16px; font-size: 10px; }
  .cc p, .cw p { margin-bottom: 36px !important; }
  .fact-card { padding: 22px 20px !important; }

  .ts { position: relative; }
  .ts::after {
    content: '← scroll →'; position: sticky; bottom: 0; left: 0;
    display: block; text-align: center;
    font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: .12em;
    text-transform: uppercase; color: var(--gold); padding: 12px 0 4px; opacity: .7;
  }
  .ts.scrolled::after { opacity: 0; transition: opacity .4s; }

  .mt th, .mt td { padding: 10px 8px; }
  .mnote { font-size: 13px; }
  .prose { font-size: 15px; line-height: 1.6; }

  .rw.tapped .rt { display: block !important; }
  .rw.tapped .redacted { animation: rg .3s ease-out; }

  .signup-section { padding-bottom: 40px; }
  .ds { font-size: clamp(22px, 5vw, 32px) !important; }
  .gr { margin: 40px 0 !important; }
}

@media (max-width: 560px) {
  .portfolio-grid { padding: 0 20px 40px; gap: 28px; }
  .portfolio-card-title { font-size: 13px; }
  .portfolio-card-type { font-size: 9px; }
  .portfolio-card-year { font-size: 10px; }
  .sp { padding: 56px 20px !important; }
  .hp { padding: 44px 20px !important; }
  .dark-section { padding: 52px 18px !important; }
  .crew-inner { padding: 0 18px !important; }
  .footer-inner { padding: 48px 20px !important; }
  .assess-box { padding: 28px 18px 24px !important; }
  .moon-cap { padding: 12px 16px !important; }

  .cc, .cw { padding: 24px 22px 36px; border-radius: 8px; }
  .cc p, .cw p { font-size: 15px !important; margin-bottom: 32px !important; }
  .cah-play-area { gap: 20px; }
  .card-hand-hint { font-size: 10px; letter-spacing: .12em; margin-bottom: 12px; }
  .cc-share-btn { font-size: 9px; padding: 7px 12px; }
  .footer-redesign { padding: 56px 20px 44px !important; }
  .footer-meta { grid-template-columns: 1fr; }
  .footer-meta-item { border-right: none !important; border-bottom: 1px solid rgba(0,0,0,.06); padding: 20px 0; }
  .footer-meta-item:last-child { grid-column: auto; border-top: none; border-bottom: none; }
  .footer-meta-label { font-size: 9px; }
  .footer-meta-value { font-size: 11px; }
  .footer-legal p { font-size: 11px; line-height: 1.6; }
  .footer-endmark-rule { font-size: 10px; letter-spacing: .16em; }
  .footer-endmark-copy { font-size: 10px; }
  .footer-signup .sf { flex-direction: column; }
  .footer-signup .sf button { width: 100%; }
  .clb { font-size: 10px; margin-bottom: 14px; }
  .tape { font-size: 11px; letter-spacing: .2em; }
  .stamp { font-size: 11px; padding: 4px 8px; border-width: 2px; }
  .sn[data-count] { font-size: clamp(28px, 10vw, 44px) !important; }
  .fact-card { padding: 18px 16px !important; border-radius: 2px; }
  .fact-card .prose { font-size: 14px; }
  .sc { padding: 18px; border-radius: 2px; }
  .sc ul { font-size: 13px !important; }
  .hl { font-size: 11px; letter-spacing: .06em; line-height: 1.6; }
  .signup-form { flex-direction: column; }
  .signup-btn { width: 100%; }
  .signup-input { font-size: 16px; }
  .nasa-worm { height: 48px !important; margin: 24px 0 32px !important; }
  .crew-card-body { padding: 18px 20px 24px !important; }
  .sh { font-size: 11px; letter-spacing: .12em; }
  .dl { font-size: 11px; letter-spacing: .1em; }
  .cost-box { padding: 16px 18px !important; border-radius: 2px; }
  .note-box { padding: 14px 18px !important; border-radius: 2px; }
  .fb { margin-top: 28px; padding-top: 18px; }
  .fi { font-size: 13px; line-height: 1.6; }
  .obj-list li { font-size: 13px !important; padding: 6px 0 !important; }
}

@media (max-width: 390px) {
  .sp { padding: 48px 16px !important; }
  .hp { padding: 40px 16px !important; }
  .dark-section { padding: 44px 14px !important; }
  .crew-inner { padding: 0 14px !important; }
  .footer-inner { padding: 40px 16px !important; }
  .assess-box { padding: 24px 14px 20px !important; }

  .cc, .cw { padding: 22px 18px 34px; border-radius: 8px; }
  .cah-play-area { gap: 16px; }
  .card-hand-hint { font-size: 9px; }
  .footer-redesign { padding: 44px 16px 36px !important; }
  .footer-meta-item { padding: 16px 0; }
  .footer-legal { padding-top: 28px; }
  .footer-endmark { padding-top: 32px; }
  .cc p, .cw p { font-size: 14px !important; line-height: 1.45 !important; }
  .s2 { gap: 10px !important; }
  .cp { aspect-ratio: 1/1; }
  .crew-card-body { padding: 16px 16px 20px !important; }
  .sn[data-count] { font-size: clamp(26px, 9vw, 40px) !important; }
  .sg > div > div:last-child { font-size: 13px !important; }
  .cb { font-size: 11px; padding: 2px 6px; }
  .nasa-worm { height: 40px !important; margin: 20px 0 28px !important; }
  .assess-box p { font-size: 14px !important; }
  .assess-box p:first-of-type { font-size: 16px !important; }
}

/* =============================================================
   RESPONSIVE — New Phase 1 Components
   ============================================================= */

/* Sticky nav mobile */
@media (max-width: 768px) {
  .sticky-nav-inner { padding: 8px 20px; }
  .sticky-nav-sep-hide { display: none; }
  .sticky-nav-status { display: none; }
  .mi-inner { padding: 56px 28px; }
  .mi-num { min-width: 100px; font-size: 11px; }
  .mi-link { font-size: 11px; }
  .mi-title { font-size: 11px; }
  .dossier-cover-inner { padding: 56px 28px 48px; }
  .stub-inner { padding: 48px 28px; }
}

@media (max-width: 560px) {
  .mi-inner { padding: 40px 20px; }
  .dossier-cover-inner { padding: 40px 20px 36px; }
  .stub-inner { padding: 36px 20px; }
  .sticky-nav-inner { padding: 8px 16px; }
  .mi-status { display: none; }
  .mi-title { max-width: 160px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
}

/* Mission Index wide screens */
@media (min-width: 1440px) {
  .mi-inner { max-width: 1320px; }
  .dossier-cover-inner { max-width: 1320px; }
  .stub-inner { max-width: 1320px; }
}

/* Love Letter mobile */
@media (max-width: 768px) {
  .love-letter-inner { padding: 100px 28px; }
  .final-card-section { padding: 0 24px 80px; }
  .final-white-grid { grid-template-columns: 1fr; gap: 16px; }
}

@media (max-width: 560px) {
  .love-letter-inner { padding: 72px 20px; }
  .final-card-section { padding: 0 18px 64px; }
}

/* =============================================================
   RESPONSIVE — Dossier Hero & Image Breaks & Portfolio Meta
   ============================================================= */

/* Dossier hero — mobile */
@media (max-width: 768px) {
  .dossier-hero-img { height: clamp(200px, 40vw, 340px); }
  .dossier-hero-meta { padding: 16px 28px 14px; }
  .dossier-hero-meta-left .dossier-hero-title { font-size: 15px; }
  .dossier-hero-meta-left .dossier-hero-type { font-size: 10px; }
  .dossier-hero-meta-right { font-size: 11px; }
  .image-break { height: clamp(160px, 28vw, 260px); }
  .image-break figcaption { padding: 12px 24px; }
  .portfolio-meta { max-width: 100%; }
  .bf-featured { grid-column: span 1; }
  .dossier-stats { grid-template-columns: repeat(2, 1fr); }
  .dossier-image-grid { grid-template-columns: 1fr; gap: 2px; }
}

@media (max-width: 560px) {
  .dossier-hero-img { height: clamp(180px, 48vw, 280px); }
  .dossier-hero-meta { padding: 14px 20px 12px; }
  .dossier-hero-meta-left .dossier-hero-title { font-size: 14px; }
  .dossier-hero-meta-right { font-size: 10px; }
  .image-break { height: clamp(140px, 35vw, 220px); }
  .image-break figcaption { padding: 10px 18px; }
  .image-break figcaption p { font-size: 10px; }
  .portfolio-meta-label { font-size: 11px; }
  .portfolio-meta-value { font-size: 14px; }
  .portfolio-meta-item { padding: 10px 0; }
  .bf-featured { padding: 24px 22px !important; }
  .bf-image { min-height: 200px; }
  .dossier-stats { grid-template-columns: 1fr; }
  .dossier-stat { padding: 16px 0; }
}

@media (max-width: 390px) {
  .dossier-hero-img { height: clamp(160px, 52vw, 240px); }
  .dossier-hero-meta { padding: 12px 16px 10px; gap: 8px; }
  .image-break { height: clamp(120px, 40vw, 180px); }
  .bf-image { min-height: 160px; }
}

/* Dossier hero — wide screens */
@media (min-width: 1440px) {
  .dossier-hero-img { height: clamp(400px, 40vw, 640px); }
  .dossier-hero-meta { padding: 24px 64px 22px; }
  .dossier-hero-meta-left .dossier-hero-title { font-size: clamp(20px, 1.8vw, 28px); }
  .image-break { height: clamp(280px, 25vw, 480px); }
  .portfolio-meta-item { padding: 16px 0; }
  .portfolio-meta-value { font-size: 16px; }
  .portfolio-meta { max-width: 640px; }
  .portfolio-grid { max-width: 1320px; padding: 0 64px 100px; gap: 24px; }
  .portfolio-card-title { font-size: 17px; }
  .portfolio-card-img { border-radius: 3px; }
}

@media (min-width: 1920px) {
  .dossier-hero-img { height: clamp(480px, 35vw, 720px); }
  .dossier-hero-meta { padding: 28px 80px 26px; }
  .dossier-hero-meta-left .dossier-hero-title { font-size: clamp(24px, 1.6vw, 32px); }
  .image-break { height: clamp(340px, 22vw, 560px); }
  .portfolio-grid { max-width: 1600px; padding: 0 80px 120px; gap: 28px; }
  .portfolio-card-title { font-size: 18px; }
  .portfolio-card-type { font-size: 12px; }
}

/* =============================================================
   RESPONSIVE — Phase 6 Interactive Features
   ============================================================= */

/* Timeline mobile */
@media (max-width: 768px) {
  .timeline-container { padding-left: 24px; }
  .timeline-entry::before { left: -30px; }
  .timeline-entry { margin-bottom: 28px; }
}
@media (max-width: 560px) {
  .timeline-container { padding-left: 20px; }
  .timeline-entry::before { left: -26px; width: 10px; height: 10px; }
}

/* Card game mobile */
@media (max-width: 560px) {
  .game-controls { display: flex; flex-direction: column; gap: 12px; align-items: center; }
  #game-draw-btn, #game-share-btn { width: 100%; max-width: 280px; margin-right: 0; }
}
