    :root{
      --bg:#ffffff;
      --surface:#ffffff;
      --text:#0f172a; /* slate-900 */
      --muted:#6b7280; /* gray-500 */
      --border:#e5e7eb; /* gray-200 */
      --accent:#CE6632; /* brand orange */
      --accent-2:#732E0C; /* brand deep */
      --shadow:0 1px 2px rgba(0,0,0,.06), 0 8px 24px rgba(0,0,0,.06);
      --radius:18px;
      --maxw:1180px;
    }
    @media (prefers-color-scheme: dark){
      :root{
        --bg:#ffffff;
        --surface:#ffffff;
        --text:#0f172a;
        --muted:#6b7280;
        --border:#e5e7eb;
        --shadow:0 1px 2px rgba(0,0,0,.06), 0 8px 24px rgba(0,0,0,.06);
      }
    }
    *,*::before,*::after{box-sizing:border-box}
    html,body{height:100%}
    body{
      margin:0; font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
      color:var(--text); background:var(--bg);
    }
    a{color:inherit; text-decoration:none}
    .container{max-width:var(--maxw); margin:0 auto; padding:0 20px}
    .skip-link{position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden}
    .skip-link:focus{left:16px; top:16px; width:auto; height:auto; background:#fff; color:#000; padding:8px 12px; border-radius:8px; box-shadow:var(--shadow)}
    /* Masthead */
    .masthead{line-height:0; border-bottom:1px solid var(--border); padding:0}
    .masthead img{width:100%; height:clamp(220px,38vw,480px); object-fit:cover; display:block}

    /* Header */
    header{position:sticky; top:0; z-index:40; background:#fff; border-bottom:1px solid var(--border)}
    @media (prefers-color-scheme: dark){
      header{background:linear-gradient(180deg, rgba(17,22,29,.7), rgba(17,22,29,.5))}
    }
    .nav{display:flex; align-items:center; justify-content:space-between; padding:12px 0}
    .brand{display:flex; align-items:center; gap:12px; font-weight:800; letter-spacing:.3px}
    .brand-badge{width:36px; height:36px; border-radius:12px; background:linear-gradient(135deg, var(--accent), var(--accent-2)); box-shadow:var(--shadow); display:grid; place-items:center}
    .brand-badge svg{filter:drop-shadow(0 2px 6px rgba(0,0,0,.25))}
    .nav a{padding:8px 12px; border-radius:10px}
    .nav a[aria-current="page"], .nav a:hover{background:#f5f5f5}
    .cta{display:inline-flex; align-items:center; gap:.55rem; background:linear-gradient(135deg,var(--accent),var(--accent-2)); color:#fff; padding:10px 14px; border-radius:12px; box-shadow:var(--shadow)}
    .cta svg{opacity:.9}
    /* Hero */
    .hero{position:relative; padding:28px 0 36px; overflow:hidden}
    .hero-bg{display:none}
    .hero-wrap{position:relative}
    .eyebrow{display:inline-flex; align-items:center; gap:.5rem; font-size:.9rem; color:var(--muted); background:#f8fafc; padding:6px 10px; border-radius:999px; border:1px solid var(--border)}
    .hero h1{font-size: clamp(2.1rem, 4vw, 3.2rem); line-height:1.1; margin:14px 0 12px; letter-spacing:-.02em}
    .hero p{font-size: clamp(1rem, 2vw, 1.125rem); color:var(--muted); max-width:60ch}
    .hero-actions{display:flex; gap:12px; margin-top:18px; flex-wrap:wrap}
    .btn{display:inline-flex; align-items:center; gap:.5rem; padding:10px 14px; border-radius:12px; border:1px solid var(--border)}
    .btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2)); color:#fff; border-color:transparent}
    .btn:hover{box-shadow:var(--shadow)}
    /* Section */
    section{padding:28px 0}
    .section-head{display:flex; align-items:end; justify-content:space-between; gap:16px; margin-bottom:12px}
    .section-head h2{font-size:1.4rem; margin:0}
    .section-head p{margin:0; color:var(--muted)}
    .grid{display:grid; grid-template-columns:repeat(12,1fr); gap:18px}
    .card{grid-column:span 4; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow)}
    @media (max-width: 900px){.card{grid-column:span 6}}
    @media (max-width: 640px){.card{grid-column:span 12}}
    .card h3{margin:0 0 6px; font-size:1.05rem}
    .card p{margin:0 0 12px; color:var(--muted)}
    .linklist{display:grid; gap:8px}
    .linklist a{display:flex; align-items:center; gap:10px; padding:10px 12px; border:1px solid var(--border); border-radius:12px}
    .linklist a:hover{border-color:rgba(206,102,50,.4); box-shadow:var(--shadow)}
    .pill{display:inline-block; font-size:.78rem; padding:.25rem .55rem; border-radius:999px; background:#f6f6f6; border:1px solid var(--border); margin-right:6px}
    /* Advertising */
    .ad-slot{display:flex; justify-content:center; padding:24px 0; margin:0 auto; max-width:min(100%, 960px)}
    .ad-slot .adsbygoogle{display:block; margin:0 auto; max-width:100%}
    body.mock-ads .adsbygoogle{display:flex; align-items:center; justify-content:center; background:repeating-linear-gradient(135deg, rgba(148,163,184,.2) 0, rgba(148,163,184,.2) 10px, rgba(226,232,240,.45) 10px, rgba(226,232,240,.45) 20px); border:1px dashed #cbd5f5; color:var(--muted); font-size:.85rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase; position:relative}
    body.mock-ads .adsbygoogle::after{content:"Mock ad"; position:absolute}
    /* Section separators */
    main>section.container{padding:40px 0; border-top:1px solid var(--border)}
    main>section.container:first-of-type{border-top:0}
    /* Book cards */
    .book{display:flex; gap:14px; align-items:center; padding:12px; border:1px solid var(--border); border-radius:14px}
    .cover{width:52px; height:72px; border-radius:8px; object-fit:cover; box-shadow:var(--shadow)}
    .book strong{display:block}
    .book span{color:var(--muted); font-size:.9rem}
    /* Calculator tiles */
    .tile{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px 14px; border:1px dashed var(--border); border-radius:14px}
    .tile:hover{border-color:rgba(206,102,50,.5); box-shadow:var(--shadow)}
    /* Search */
    .search{display:flex; gap:10px; align-items:center; border:1px solid var(--border); padding:10px 12px; border-radius:12px; background:var(--surface)}
    .search input{border:0; outline:0; background:transparent; color:inherit; flex:1; font-size:1rem}
    /* Promo slab */
    .feature-slab{background:linear-gradient(180deg, rgba(206,102,50,.08), #fff); border:1px solid var(--border); border-radius:var(--radius); padding:20px; box-shadow:var(--shadow)}
    .pill.accent{background:rgba(206,102,50,.12); border-color:rgba(206,102,50,.4); color:var(--accent-2)}
    .tip-of-day{background:linear-gradient(180deg, rgba(115,46,12,.06), #fff); border:1px solid var(--border); border-radius:var(--radius); padding:20px; box-shadow:var(--shadow)}
    .tip-of-day h2{margin:0 0 8px; font-size:1.4rem}
    .tip-of-day p{margin:0; color:var(--muted)}
    .tip-content{margin-top:14px; border:1px solid var(--border); border-radius:14px; padding:14px; background:var(--surface)}
    .tip-content strong{display:block; margin-bottom:8px}
    .tip-content ul{margin:10px 0 0 1.2rem}
    .tip-content li{margin-bottom:8px}
    .tip-meta{margin-top:10px; font-size:.9rem; color:var(--muted)}
    /* Footer */
    footer{margin-top:36px; padding:28px 0 40px; border-top:1px solid var(--border); color:var(--muted)}
    .made{display:flex; gap:8px; align-items:center}
    .sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0}
    .faq{padding:40px 0; border-top:1px solid var(--border)}
    .faq h2{margin-top:0; font-size:1.4rem}
    .faq-item{border:1px solid var(--border); border-radius:var(--radius); padding:16px; margin-bottom:16px; background:var(--surface); box-shadow:var(--shadow)}
    .faq-item h3{margin:0 0 8px; font-size:1.05rem}
    .faq-item p{margin:0; color:var(--muted)}
    .guide{padding:40px 0; border-top:1px solid var(--border)}
    .guide-content{max-width:72ch}
    .guide-content h2{margin:0 0 12px; font-size:1.4rem}
    .guide-content p{margin:0 0 12px; color:var(--muted)}
    .guide-content ol{margin:0 0 12px 1.4rem; padding:0}
    .guide-content li{margin-bottom:10px}
  

    .nav-links{display:flex; gap:6px; align-items:center}
    .hero-gradient-text{background:linear-gradient(135deg,var(--accent),var(--accent-2)); -webkit-background-clip:text; background-clip:text; color:transparent}
    .search-wrap{margin-top:18px; max-width:680px}
    .ad-banner-728x90{display:inline-block; width:728px; height:90px}
    .ad-center{display:flex; justify-content:center}
    .footer-row{display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap}
    .copyright-meta{opacity:.8}
    .footer-link-spaced{margin-right:12px}

    .card.span-6{grid-column:span 6}

    .masthead img{height:clamp(150px,22vw,260px)}
    .hero{padding:28px 0 32px}
    .hero h1{
      max-width:980px;
      font-size:2.65rem;
      letter-spacing:0
    }
    .hero p{max-width:68ch}
    .hero-actions .btn{border-radius:8px}

    main>section.container{padding:40px 20px}

    .front-page,
    .tools-desk,
    .issue-grid,
    .sessions-strip{padding-top:44px}

    .magazine-layout{
      display:grid;
      grid-template-columns:repeat(12,1fr);
      gap:18px;
      align-items:stretch
    }

    .story-card{
      grid-column:span 4;
      background:var(--surface);
      border:1px solid var(--border);
      border-radius:8px;
      overflow:hidden;
      box-shadow:0 1px 2px rgba(15,23,42,.06);
      transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease
    }

    .story-card:hover{
      transform:translateY(-2px);
      border-color:rgba(206,102,50,.34);
      box-shadow:0 16px 34px rgba(15,23,42,.1)
    }

    .story-card a{
      display:flex;
      flex-direction:column;
      min-height:100%
    }

    .story-card figure{
      margin:0;
      aspect-ratio:16 / 10;
      background:#f1f5f9;
      overflow:hidden
    }

    .story-card img{
      width:100%;
      height:100%;
      display:block;
      object-fit:cover;
      transition:transform .25s ease
    }

    .story-card:hover img{transform:scale(1.03)}

    .story-body{
      display:flex;
      flex:1;
      flex-direction:column;
      gap:10px;
      padding:16px
    }

    .story-meta{
      display:flex;
      align-items:center;
      gap:8px;
      flex-wrap:wrap;
      color:var(--muted);
      font-size:.78rem;
      font-weight:700;
      line-height:1.3;
      text-transform:uppercase
    }

    .story-meta time{margin-left:auto}

    .article-new{
      display:inline-flex;
      align-items:center;
      border-radius:999px;
      background:var(--accent);
      color:#fff;
      padding:2px 7px;
      font-size:.7rem;
      line-height:1.3
    }

    .story-card h3{
      margin:0;
      font-size:1.18rem;
      line-height:1.18;
      letter-spacing:0
    }

    .story-card p{
      margin:0;
      color:var(--muted);
      font-size:.95rem;
      line-height:1.55
    }

    .story-card--lead{grid-column:span 8}

    .story-card--lead a{
      display:grid;
      grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr)
    }

    .story-card--lead figure{
      aspect-ratio:auto;
      min-height:100%
    }

    .story-card--lead .story-body{
      justify-content:end;
      padding:32px
    }

    .story-card--lead h3{font-size:2rem}

    .front-rail{
      grid-column:span 4;
      display:flex;
      flex-direction:column;
      border-top:3px solid var(--text);
      border-bottom:1px solid var(--border)
    }

    .rail-heading{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      padding:0 0 12px;
      border-bottom:1px solid var(--border)
    }

    .rail-heading h2{
      margin:0;
      font-size:1rem;
      text-transform:uppercase
    }

    .rail-link{
      display:grid;
      gap:4px;
      padding:15px 0;
      border-bottom:1px solid var(--border)
    }

    .rail-link:last-child{border-bottom:0}
    .rail-link span,
    .session-row span,
    .tool-kicker{
      color:var(--accent-2);
      font-size:.78rem;
      font-weight:800;
      line-height:1.2;
      text-transform:uppercase
    }
    .rail-link strong{font-size:1.02rem; line-height:1.25}
    .rail-link small,
    .session-row small{color:var(--muted); font-size:.9rem; line-height:1.45}
    .rail-link:hover strong,
    .session-row:hover strong{text-decoration:underline}

    .tool-grid{
      display:grid;
      grid-template-columns:repeat(4,1fr);
      gap:12px
    }

    .tool-card{
      display:flex;
      gap:13px;
      min-height:142px;
      align-items:flex-start;
      border:1px solid var(--border);
      border-radius:8px;
      padding:16px;
      background:#fff;
      box-shadow:0 1px 2px rgba(15,23,42,.05)
    }

    .tool-card:hover{
      border-color:rgba(206,102,50,.4);
      box-shadow:var(--shadow)
    }

    .tool-icon{
      display:grid;
      width:42px;
      height:42px;
      flex:0 0 42px;
      place-items:center;
      border:1px solid rgba(206,102,50,.28);
      border-radius:8px;
      background:rgba(206,102,50,.08);
      color:var(--accent-2)
    }

    .tool-icon svg{
      width:23px;
      height:23px;
      fill:none;
      stroke:currentColor;
      stroke-width:1.9;
      stroke-linecap:round;
      stroke-linejoin:round
    }

    .tool-copy{
      display:grid;
      gap:7px;
      min-width:0
    }

    .tool-card strong{
      font-size:1.08rem;
      line-height:1.2
    }

    .tool-copy span:last-child{
      color:var(--muted);
      line-height:1.45
    }

    .tool-card--feature{
      grid-column:span 2;
      align-items:center;
      background:linear-gradient(180deg, rgba(206,102,50,.1), #fff)
    }

    .tool-card--feature .tool-icon{
      width:54px;
      height:54px;
      flex-basis:54px;
      background:linear-gradient(135deg,var(--accent),var(--accent-2));
      border-color:transparent;
      color:#fff
    }

    .tool-card--feature .tool-icon svg{
      width:29px;
      height:29px
    }

    .tool-card--feature strong{
      font-size:1.25rem
    }

    .issue-board{
      border:1px solid var(--border);
      border-top:4px solid var(--text);
      border-radius:8px;
      background:#f8fafc;
      box-shadow:0 1px 2px rgba(15,23,42,.05)
    }

    .issue-board-head{
      display:flex;
      align-items:flex-end;
      justify-content:space-between;
      gap:18px;
      padding:20px;
      border-bottom:1px solid var(--border);
      background:#fff
    }

    .issue-board-head h2{
      margin:4px 0 2px;
      font-size:1.45rem;
      line-height:1.2
    }

    .issue-board-head p{
      margin:0;
      color:var(--muted)
    }

    .issue-label,
    .issue-topic{
      color:var(--accent-2);
      font-size:.76rem;
      font-weight:800;
      line-height:1.2;
      text-transform:uppercase
    }

    .section-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:0
    }

    .section-card{
      display:flex;
      flex-direction:column;
      gap:14px;
      min-height:100%;
      padding:20px;
      border-right:1px solid var(--border)
    }

    .section-card:last-child{border-right:0}

    .section-card-head{
      display:flex;
      align-items:flex-start;
      gap:12px
    }

    .issue-number{
      display:grid;
      width:42px;
      height:42px;
      flex:0 0 42px;
      place-items:center;
      border:1px solid rgba(15,23,42,.18);
      border-radius:50%;
      background:#fff;
      color:var(--text);
      font-size:.8rem;
      font-weight:900;
      line-height:1
    }

    .section-card h3{
      margin:2px 0 0;
      font-size:1.3rem;
      line-height:1.15
    }

    .section-card p{
      margin:0;
      color:var(--muted)
    }

    .issue-links{
      display:grid;
      margin-top:auto;
      border-top:1px solid var(--border)
    }

    .issue-links a{
      display:grid;
      grid-template-columns:78px minmax(0,1fr);
      gap:12px;
      align-items:center;
      padding:12px 0;
      border-bottom:1px solid var(--border)
    }

    .issue-links a:last-child{border-bottom:0}

    .issue-links a span{
      color:var(--muted);
      font-size:.76rem;
      font-weight:800;
      text-transform:uppercase
    }

    .issue-links a strong{
      font-size:.98rem;
      line-height:1.25
    }

    .issue-links a:hover strong{text-decoration:underline}

    .tip-of-day{border-radius:8px}
    .tip-content{border-radius:8px}

    .session-list{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:12px
    }

    .session-row{
      display:grid;
      gap:7px;
      min-height:120px;
      border:1px solid var(--border);
      border-radius:8px;
      padding:16px;
      background:#fff
    }

    .session-row:hover{
      border-color:rgba(206,102,50,.4);
      box-shadow:var(--shadow)
    }

    .session-row strong{
      font-size:1.05rem;
      line-height:1.25
    }

    @media (max-width: 980px){
      .hero h1{font-size:2.35rem}
      .story-card,
      .story-card--lead,
      .front-rail{grid-column:span 6}
      .story-card--lead a{display:flex}
      .story-card--lead figure{aspect-ratio:16 / 10}
      .story-card--lead .story-body{padding:20px}
      .story-card--lead h3{font-size:1.45rem}
      .tool-grid{grid-template-columns:repeat(2,1fr)}
      .session-list{grid-template-columns:1fr}
      .section-grid{grid-template-columns:1fr}
      .section-card{
        border-right:0;
        border-bottom:1px solid var(--border)
      }
      .section-card:last-child{border-bottom:0}
    }

    @media (max-width: 700px){
      .nav{
        align-items:flex-start;
        flex-direction:column;
        gap:8px
      }
      .nav-links{
        flex-wrap:wrap;
        gap:2px
      }
      .nav a{padding:7px 9px}
      .masthead img{height:160px}
      .hero h1{font-size:2rem}
      .hero-actions{gap:8px}
      .hero-actions .btn{width:100%; justify-content:center}
      .magazine-layout{gap:14px}
      .story-card,
      .story-card--lead,
      .front-rail{grid-column:span 12}
      .story-meta time{margin-left:0}
      .tool-grid{grid-template-columns:1fr}
      .tool-card--feature{grid-column:auto}
      .tool-card{min-height:auto}
      .section-head,
      .issue-board-head{
        align-items:flex-start;
        flex-direction:column
      }
      .issue-board-head,
      .section-card{padding:16px}
      .issue-links a{
        grid-template-columns:1fr;
        gap:4px
      }
      .ad-banner-728x90{
        width:320px;
        height:100px
      }
    }
