:root{
    --ink:#15171C;
    --ink-soft:#5A5E66;
    --shell:#F7F6F3;
    --shell-deep:#EDECE7;
    --paper:#FFFFFF;
    --coral:#1b1c1f;
    --coral-deep:#000000;
    --seafoam:#15171C;
    --plum:#15171C;
    --sun:#15171C;
    --line:rgba(21,23,28,.13);
    --line-soft:rgba(21,23,28,.07);
    --up:#1b1c1f;
    --down:#9a9da3;
    --t-teal:#55585d;
    --t-teal-d:#2b2d31;
    --t-coral:#55585d;
    --t-coral-d:#2b2d31;
    --t-sun:#9a9da3;
    --t-up:#1b1c1f;
    --t-down:#9a9da3;
    --display:"Bricolage Grotesque", system-ui, sans-serif;
    --serif:"Newsreader", Georgia, serif;
    --mono:"Archivo", system-ui, -apple-system, sans-serif;
    --wrap:1240px;
  }

  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0;
    background:var(--shell);
    color:var(--ink);
    font-family:var(--serif);
    font-size:18px;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
  }
  a{color:inherit;text-decoration:none;}
  img{max-width:100%;display:block;}
  .wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px;}

  ::selection{background:var(--coral);color:#fff;}
  a:focus-visible,button:focus-visible{outline:3px solid var(--coral);outline-offset:3px;border-radius:0;}

  /* ---------- eyebrow / labels ---------- */
  .eyebrow{
    font-family:var(--mono);
    font-size:11px;
    letter-spacing:.18em;
    text-transform:uppercase;
    font-weight:700;
  }
  .cat{
    font-family:var(--mono);
    font-size:11px;
    letter-spacing:.16em;
    text-transform:uppercase;
    font-weight:700;
    display:inline-flex;
    align-items:center;
    gap:7px;
    color:var(--ink-soft);
  }
  .cat::before{
    content:"";
    width:6px;height:6px;border-radius:50%;
    background:var(--coral);
    flex:none;
  }
  .cat.coral,.cat.plum,.cat.sun,.cat.ink{color:var(--ink-soft);}

  h1,h2,h3{font-family:var(--display);font-weight:700;line-height:1.02;letter-spacing:-.015em;margin:0;}

  /* ---------- top utility bar ---------- */
  .topbar{
    background:var(--ink);
    color:var(--shell);
    font-family:var(--mono);
    font-size:11px;
    letter-spacing:.14em;
    text-transform:uppercase;
  }
  .topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;gap:18px;}
  .topbar .date{opacity:.7;}
  .topbar .util{display:flex;gap:22px;}
  .topbar .util a{position:relative;opacity:.85;transition:opacity .2s;}
  .topbar .util a:hover{opacity:1;color:#fff;}

  /* ---------- masthead (logo row + CTA) ---------- */
  .masthead{background:var(--paper);}
  .masthead .wrap{display:flex;align-items:center;justify-content:flex-start;padding-top:18px;padding-bottom:10px;}
  .navlogo{
    display:inline-flex;align-items:center;flex:none;line-height:0;
  }
  .navlogo .logo-img{height:clamp(30px,3.2vw,40px);width:auto;display:block;}
  .navlogo::after{display:none;}
  .masthead-cta{
    flex:none;font-family:var(--mono);font-size:13px;letter-spacing:.04em;font-weight:600;
    background:var(--ink);color:var(--paper);padding:15px 28px;border-radius:0;
    transition:background .2s,transform .2s;
  }
  .masthead-cta:hover{background:#000;transform:translateY(-2px);}

  /* ---------- search band (toggled open from nav) ---------- */
  .searchband{background:var(--shell);border-bottom:1px solid var(--line);display:none;}
  .searchband.open{display:block;}
  .searchband .wrap{padding-top:16px;padding-bottom:16px;}
  .search{
    display:flex;align-items:center;gap:0;
    max-width:none;margin:0;
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:0;
    padding:5px 5px 5px 16px;
    transition:box-shadow .2s,border-color .2s;
  }
  .search:focus-within{box-shadow:0 0 0 3px rgba(21,23,28,.14);border-color:var(--ink);}
  .search-ic{width:18px;height:18px;color:var(--ink-soft);flex:none;}
  .search input{
    flex:1;border:0;background:transparent;outline:none;
    font-family:var(--serif);font-size:16px;color:var(--ink);
    padding:9px 12px;min-width:0;
  }
  .search input::placeholder{color:var(--ink-soft);}
  .search button{
    flex:none;border:0;cursor:pointer;
    background:var(--ink);color:var(--paper);
    font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
    padding:10px 18px;border-radius:0;
    transition:background .2s;
  }
  .search button:hover{background:#000;}

  /* ---------- nav ---------- */
  nav.cats{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.78);-webkit-backdrop-filter:saturate(150%) blur(14px);backdrop-filter:saturate(150%) blur(14px);border-bottom:1px solid var(--line);}
  nav.cats .wrap{display:flex;align-items:center;gap:0 18px;min-height:auto;padding-top:12px;padding-bottom:11px;flex-wrap:wrap;}
  .searchtoggle{
    display:inline-flex;align-items:center;justify-content:center;cursor:pointer;
    background:none;border:0;color:var(--ink);padding:6px;flex:none;border-radius:0;
    transition:background .2s;
  }
  .searchtoggle:hover{background:var(--shell-deep);}
  .searchtoggle svg{width:20px;height:20px;}
  nav.cats .catlinks{display:flex;align-items:center;gap:4px 6px;flex-wrap:wrap;}
  nav.cats a{
    position:relative;
    font-family:var(--mono);
    font-size:13px;
    letter-spacing:.04em;
    text-transform:uppercase;
    font-weight:600;
    padding:4px 11px;
    color:var(--ink-soft);
    transition:color .2s;
  }
  nav.cats a::after{
    content:"";
    position:absolute;left:11px;right:11px;bottom:2px;height:2px;
    background:var(--coral);
    transform:scaleX(0);transform-origin:left;
    transition:transform .25s ease;
  }
  nav.cats a:hover{color:var(--ink);}
  nav.cats a:hover::after{transform:scaleX(1);}
  nav.cats a.live{color:var(--ink);}
  nav.cats a.live::after{transform:scaleX(1);}

  /* ---------- cover art system ---------- */
  .cover{
    position:relative;
    border-radius:0;
    overflow:hidden;
    background:var(--ink);
    isolation:isolate;
  }
  .cover::after{
    content:"";
    position:absolute;inset:0;
    background-image:
      radial-gradient(120% 90% at 12% -10%, rgba(255,255,255,.22), transparent 55%),
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='320' height='80' viewBox='0 0 320 80'%3E%3Cpath d='M0 56 C 40 30 80 30 120 56 S 200 82 240 56 320 30 360 56' fill='none' stroke='rgba(255,255,255,0.16)' stroke-width='2'/%3E%3Cpath d='M0 70 C 40 44 80 44 120 70 S 200 96 240 70 320 44 360 70' fill='none' stroke='rgba(255,255,255,0.1)' stroke-width='2'/%3E%3C/svg%3E");
    background-size:auto, 360px 90px;
    mix-blend-mode:overlay;
    opacity:.9;
  }
  .cover .label{
    position:absolute;left:0;bottom:0;
    font-family:var(--display);
    font-weight:800;
    color:rgba(255,255,255,.16);
    letter-spacing:-.04em;
    line-height:.78;
    padding:0 0 8px 16px;
    text-transform:uppercase;
    z-index:1;
    pointer-events:none;
  }
  .c-wellness{background:linear-gradient(140deg,#3A3E46,#15171C);}
  .c-beauty{background:linear-gradient(140deg,#46484E,#1A1C20);}
  .c-food{background:linear-gradient(140deg,#33363C,#131418);}
  .c-business{background:linear-gradient(140deg,#3E424A,#16181D);}
  .c-events{background:linear-gradient(140deg,#4A4C52,#1C1E22);}
  .c-lifestyle{background:linear-gradient(140deg,#383B42,#141519);}

  /* ---------- hero ---------- */
  .hero{padding:48px 0 12px;}
  .lead{display:grid;grid-template-columns:1fr minmax(300px,440px);gap:54px;align-items:center;}
  .lead-text{min-width:0;}
  .lead-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:20px;flex-wrap:wrap;}
  .lead-eyebrow .pill{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
    background:var(--ink);color:var(--paper);padding:6px 14px;border-radius:0;}
  .lead h1{font-size:clamp(34px,4vw,58px);line-height:1.02;letter-spacing:-.02em;margin:0 0 14px;}
  .lead h1 a:hover{color:var(--ink-soft);transition:color .2s;}
  .lead .byline{display:block;margin:0 0 18px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:none;color:var(--ink-soft);}
  .lead .dek{font-size:19px;line-height:1.55;color:var(--ink-soft);max-width:54ch;margin:0 0 26px;}
  .lead-img{display:block;}
  .lead-img .cover{display:block;aspect-ratio:1/1;width:100%;border-radius:0;background-size:cover;background-position:center;background-color:var(--ink);position:relative;overflow:hidden;}
  .lead-img .cover .label{position:absolute;left:16px;bottom:10px;font-family:var(--display);font-weight:800;color:rgba(255,255,255,.16);font-size:48px;text-transform:uppercase;}

  .byline{margin-top:18px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-soft);}

  .secondaries{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:48px;padding-top:40px;border-top:1px solid var(--line);}
  .card.sm h3{font-size:19px;line-height:1.1;margin-bottom:8px;}
  .card.sm .cat{margin-bottom:8px;}
  .card.sm .byline{margin-top:6px;}

  /* ---------- divider ---------- */
  .rule{display:flex;align-items:center;gap:18px;margin:54px 0 26px;}
  .rule h2{font-size:clamp(24px,2.6vw,34px);white-space:nowrap;}
  .rule .ln{flex:1;height:1px;background:var(--line);}
  .rule .more{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--coral-deep);white-space:nowrap;}
  .rule .more:hover{text-decoration:underline;}

  /* ---------- latest strip ---------- */
  .strip{background:var(--ink);color:var(--shell);border-radius:0;padding:30px 34px;}
  .strip .head{display:flex;align-items:center;gap:14px;margin-bottom:8px;}
  .strip .head .eyebrow{color:rgba(255,255,255,.85);}
  .strip .head .pulse{width:9px;height:9px;border-radius:50%;background:#fff;animation:pulse 1.6s ease-in-out infinite;}
  @keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.35;transform:scale(.7);}}
  .strip ol{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:0 36px;}
  .strip li{padding:18px 0;border-bottom:1px solid rgba(255,255,255,.14);display:flex;gap:16px;align-items:flex-start;}
  .strip li:nth-last-child(-n+3){border-bottom:0;}
  .strip .num{font-family:var(--mono);font-size:13px;color:rgba(255,255,255,.55);font-weight:700;flex:none;padding-top:2px;}
  .strip .ttl{font-family:var(--display);font-weight:600;font-size:18px;line-height:1.12;}
  .strip .meta{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(245,243,237,.55);margin-top:6px;}
  .strip li a:hover .ttl{color:#fff;transition:color .2s;}

  /* ---------- TODAY: the interactive, colorful centerpiece ---------- */
  .today{
    margin:50px 0 8px;
    padding:34px 0 40px;
    background:
      radial-gradient(120% 140% at 0% 0%, rgba(21,23,28,.05), transparent 55%),
      radial-gradient(120% 140% at 100% 0%, rgba(21,23,28,.04), transparent 52%),
      linear-gradient(180deg,#fbfaf7,#f3f1ec);
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
  }
  .today-inner{}
  .today .bar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap;}
  .today .today-kicker{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;
    background:linear-gradient(90deg,var(--t-teal),var(--t-coral));-webkit-background-clip:text;background-clip:text;color:transparent;}
  .today .bar h2{font-size:clamp(24px,2.8vw,36px);margin-top:6px;letter-spacing:-.02em;}
  .today-live{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--t-coral-d);}
  .today-live.small{font-size:10px;}
  .today-live .pd{width:8px;height:8px;border-radius:50%;background:var(--t-coral);box-shadow:0 0 0 0 rgba(21,23,28,.4);animation:livepulse 1.8s ease-out infinite;}
  @keyframes livepulse{0%{box-shadow:0 0 0 0 rgba(21,23,28,.4);}70%{box-shadow:0 0 0 7px rgba(21,23,28,0);}100%{box-shadow:0 0 0 0 rgba(21,23,28,0);}}

  /* Today: full-width Long Island news, 3 columns x 3 stories (column flow) */
  .today-news{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,auto);grid-auto-flow:column;column-gap:38px;}
  .tn-item{display:flex;flex-direction:column;gap:8px;padding:17px 2px 18px;border-top:1px solid var(--line);text-decoration:none;color:var(--ink);transition:padding-left .15s ease;}
  .tn-item:hover{padding-left:6px;}
  .tn-meta{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;}
  .tn-src{font-weight:700;color:var(--t-coral-d);}
  .tn-ago{color:var(--ink-soft);}
  .tn-title{font-family:var(--display);font-weight:600;font-size:18px;line-height:1.24;letter-spacing:-.01em;}
  .tn-item:hover .tn-title{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:2px;}
  @media(max-width:1040px){ .today-news{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(5,auto);} }
  @media(max-width:680px){ .today-news{grid-template-columns:1fr;grid-template-rows:none;grid-auto-flow:row;column-gap:0;} }

  .dash{display:grid;grid-template-columns:1fr 1.02fr 1.18fr;gap:18px;align-items:start;}
  .panel-embed{padding:14px;min-height:240px;}
  .panel-embed .elfsight-app-e6427c1c-a7a4-4d2f-a417-eeb9c5c6d433,
  .panel-embed [class^="elfsight-app-"]{width:100%;}
  .panel{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:0;padding:0;display:flex;flex-direction:column;overflow:hidden;
    box-shadow:0 14px 30px -22px rgba(21,23,28,.35);transition:transform .25s,box-shadow .25s;}
  .panel:hover{transform:translateY(-3px);box-shadow:0 22px 44px -24px rgba(21,23,28,.45);}
  .panel::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;}
  .p-weather::before{background:linear-gradient(90deg,#1f2125,#9a9da3);}
  .p-markets::before{background:linear-gradient(90deg,var(--t-up),var(--t-down));}
  .p-breaking::before{background:linear-gradient(90deg,var(--t-coral),var(--t-sun));}
  .panel .ptitle{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 13px;border-bottom:1px solid var(--line-soft);}
  .panel .ptitle .lbl{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;}
  .p-weather .ptitle .lbl{color:var(--t-teal-d);}
  .p-markets .ptitle .lbl{color:var(--ink);}
  .p-breaking .ptitle .lbl{color:var(--t-coral-d);}
  .panel .ptitle .meta{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);}
  .shimmer{position:relative;color:var(--ink-soft);}
  .shimmer::after{content:"";position:absolute;left:-2px;right:-2px;top:0;bottom:0;
    background:linear-gradient(90deg,transparent,rgba(21,23,28,.16),transparent);background-size:200% 100%;animation:shim 2.6s linear infinite;}
  @keyframes shim{0%{background-position:200% 0;}100%{background-position:-200% 0;}}

  /* weather */
  .wx-stage{display:flex;align-items:center;gap:20px;padding:26px 24px 18px;flex:1;
    background:linear-gradient(160deg,rgba(21,23,28,.05),rgba(21,23,28,.012));}
  .wx-icon{width:78px;height:78px;flex:none;color:var(--t-teal-d);}
  .wx-read{line-height:1;}
  .wx-temp{font-family:var(--display);font-weight:800;font-size:68px;letter-spacing:-.03em;line-height:.82;color:var(--ink);}
  .wx-temp span{font-size:28px;color:var(--t-teal-d);vertical-align:top;}
  .wx-cond{font-family:var(--serif);font-size:18px;color:var(--ink);margin-top:8px;font-weight:600;}
  .wx-hl{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--ink-soft);margin-top:6px;}
  .wx-hl b{color:var(--ink);}
  .wx-days{display:flex;gap:8px;padding:8px 18px 18px;flex:1;align-items:stretch;}
  .wx-day{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:6px;cursor:pointer;
    background:var(--shell);border:1px solid transparent;border-radius:0;padding:16px 6px;
    font:inherit;transition:background .2s,border-color .2s,transform .15s;}
  .wx-day:hover{transform:translateY(-2px);background:#eeeeec;}
  .wx-day.active{background:linear-gradient(160deg,#2b2d31,#15171c);border-color:#15171c;}
  .wx-day .d{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);}
  .wx-day .h{font-family:var(--display);font-weight:700;font-size:24px;color:var(--ink);}
  .wx-day .lo{font-family:var(--mono);font-size:12px;color:var(--ink-soft);}
  .wx-day .r{font-family:var(--mono);font-size:10px;color:var(--t-teal-d);margin-top:2px;}
  .wx-day .mini{width:24px;height:24px;color:var(--t-teal-d);}
  .wx-day.active .d,.wx-day.active .h,.wx-day.active .lo,.wx-day.active .r,.wx-day.active .mini{color:#fff;}
  .wx-day.active .lo{color:rgba(255,255,255,.7);}

  /* markets */
  .mkt{display:flex;flex-direction:column;flex:1;gap:9px;padding:14px 20px 16px;}
  .mkt-row{display:grid;gap:8px;}
  .mkt-row.idx3{grid-template-columns:repeat(3,1fr);}
  .mkt-row.stk2{grid-template-columns:repeat(2,1fr);flex:1;grid-auto-rows:1fr;}
  .mkt-row.cry2{grid-template-columns:repeat(2,1fr);}
  .q{display:flex;flex-direction:column;justify-content:center;gap:3px;
    background:var(--shell);border:1px solid transparent;border-radius:0;padding:12px 14px;
    transition:background .2s,transform .15s;}
  .q:hover{transform:translateY(-2px);background:#eeeeec;}
  .q .qn{font-family:var(--display);font-weight:600;font-size:13px;color:var(--ink);line-height:1.1;}
  .q .qv{font-family:var(--mono);font-weight:700;font-size:17px;color:var(--ink);letter-spacing:-.01em;}
  .q .qc{font-family:var(--mono);font-size:11px;font-weight:700;}
  .q .qc.up{color:var(--t-up);}
  .q .qc.down{color:var(--t-down);}
  .q .qc.up::before{content:"\25B2 ";font-size:8px;}
  .q .qc.down::before{content:"\25BC ";font-size:8px;}
  .mkt-sub{flex:none;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--ink-soft);
    padding-top:6px;}
  .mkt .note{flex:none;font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);padding-top:6px;}

  /* breaking */
  .brk{display:flex;flex-direction:column;flex:1;justify-content:space-between;padding:6px 14px 4px;}
  .brk-item{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;padding:12px;border-radius:0;border:1px solid transparent;transition:background .2s,border-color .2s;}
  .brk-item .n{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--ink-soft);padding-top:2px;}
  .brk-item .bt{font-family:var(--display);font-weight:600;font-size:16px;line-height:1.16;color:var(--ink);}
  .brk-item .bm{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-top:5px;}
  .brk-item.active{background:linear-gradient(120deg,rgba(21,23,28,.07),rgba(21,23,28,.03));border-color:rgba(21,23,28,.16);}
  .brk-item.active .n{color:var(--t-coral-d);}
  .brk-item:hover .bt{color:var(--t-coral-d);}
  .brk-dots{display:flex;gap:7px;justify-content:center;padding:8px 0 16px;}
  .brk-dots .dot{width:8px;height:8px;border-radius:50%;border:0;background:rgba(21,23,28,.18);cursor:pointer;padding:0;transition:background .2s,transform .2s;}
  .brk-dots .dot.active{background:var(--t-coral);transform:scale(1.25);}

  @media(max-width:900px){ .dash{grid-template-columns:1fr;} }
  @media(prefers-reduced-motion:reduce){
    .spark-line{animation:none;stroke-dashoffset:0;}
    .today-live .pd,.shimmer::after{animation:none;}
  }


  /* ---------- card grid ---------- */
  .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 30px;}
  .card{display:flex;flex-direction:column;}
  .card .cover{aspect-ratio:1/1;margin-bottom:15px;}
  .card .cover .label{font-size:30px;}
  .card .cat{margin-bottom:9px;}
  .card h3{font-size:22px;line-height:1.06;margin-bottom:9px;}
  .card p{font-size:16px;color:var(--ink-soft);margin:0 0 12px;}
  .card .byline{margin-top:auto;}
  .card a.head:hover h3{color:var(--coral-deep);transition:color .2s;}
  .card .cover{transition:transform .3s ease, box-shadow .3s ease;}
  .card a.head:hover .cover{transform:translateY(-3px);box-shadow:0 16px 30px -18px rgba(21,23,28,.5);}
  .card h3{transition:color .2s;}

  /* ---------- spotlight band ---------- */
  .spotlight{background:var(--ink);color:var(--shell);margin-top:64px;}
  .spotlight .wrap{padding-top:64px;padding-bottom:64px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
  .spotlight .cover{aspect-ratio:4/3;}
  .spotlight .cover .label{font-size:54px;}
  .spotlight .eyebrow{color:var(--coral);}
  .spotlight h2{font-size:clamp(30px,3.6vw,48px);margin:16px 0 18px;}
  .spotlight p{font-size:19px;color:rgba(245,243,237,.82);max-width:54ch;}
  .spotlight .quote{font-family:var(--serif);font-style:italic;font-size:24px;line-height:1.4;color:var(--shell);border-left:3px solid var(--coral);padding-left:20px;margin:24px 0;}

  .btn{
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
    background:var(--coral);color:#fff;
    padding:15px 26px;border-radius:0;border:0;cursor:pointer;
    transition:transform .2s,background .2s;
  }
  .btn:hover{background:var(--coral-deep);transform:translateY(-2px);}
  .btn.ghost{background:transparent;border:1.5px solid currentColor;color:var(--ink);}
  .btn.ghost:hover{background:var(--ink);color:var(--shell);border-color:var(--ink);}
  .btn .arr{font-family:var(--serif);font-size:16px;font-weight:600;}

  /* ---------- advertise ---------- */
  .advertise{padding:72px 0 8px;}
  .advertise .lede{max-width:680px;margin:0 auto 40px;text-align:center;}
  .advertise .lede h2{font-size:clamp(28px,3.4vw,44px);margin-bottom:16px;}
  .advertise .lede p{color:var(--ink-soft);font-size:19px;margin:0;}
  .advertise .promo{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--coral-deep);font-weight:700;margin-bottom:14px;display:inline-block;}
  .tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
  .tier{
    background:var(--paper);border:1px solid var(--line);border-radius:0;padding:30px 26px;display:flex;flex-direction:column;
    transition:transform .2s,box-shadow .2s,border-color .2s;
  }
  .tier:hover{transform:translateY(-4px);box-shadow:0 18px 40px -22px rgba(11,36,64,.4);border-color:var(--ink);}
  .tier.feat{background:var(--ink);color:var(--shell);border-color:var(--ink);}
  .tier .name{font-family:var(--display);font-weight:700;font-size:24px;}
  .tier .flag{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--coral);margin-bottom:10px;min-height:14px;}
  .tier .price{font-family:var(--display);font-weight:800;font-size:42px;margin:14px 0 2px;letter-spacing:-.03em;}
  .tier .price span{font-family:var(--mono);font-size:13px;font-weight:400;letter-spacing:.06em;}
  .tier .was{font-family:var(--mono);font-size:12px;color:var(--ink-soft);text-decoration:line-through;margin-bottom:18px;}
  .tier.feat .was{color:rgba(245,243,237,.55);}
  .tier ul{list-style:none;margin:0 0 24px;padding:0;flex:1;}
  .tier li{font-size:16px;padding:9px 0;border-bottom:1px solid var(--line-soft);display:flex;gap:10px;}
  .tier.feat li{border-color:rgba(255,255,255,.12);}
  .tier li::before{content:"~";font-family:var(--mono);color:var(--coral);font-weight:700;}
  .tier .btn{width:100%;justify-content:center;}
  .tier.feat .btn.ghost{color:var(--shell);}
  .tier.feat .btn.ghost:hover{background:var(--shell);color:var(--ink);border-color:var(--shell);}

  /* ---------- newsletter ---------- */
  .signup{margin-top:72px;background:var(--shell-deep);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
  .signup .wrap{padding:56px 28px;display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center;}
  .signup h2{font-size:clamp(26px,3vw,40px);margin-bottom:12px;}
  .signup p{color:var(--ink-soft);margin:0;font-size:18px;max-width:46ch;}
  .signup form{display:flex;gap:10px;flex-wrap:wrap;}
  .signup input{
    flex:1;min-width:220px;font-family:var(--serif);font-size:17px;
    padding:15px 18px;border:1.5px solid var(--ink);border-radius:0;background:var(--paper);color:var(--ink);
  }
  .signup input::placeholder{color:var(--ink-soft);}
  .signup .fine{display:block;margin-top:14px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);}

  /* ---------- footer ---------- */
  footer{background:var(--ink);color:var(--shell);padding:60px 0 40px;}
  footer .top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.14);}
  footer .wordmark{font-size:28px;}
  footer .wordmark .wv{color:#9a9da3;}
  .footer-logo{display:inline-block;line-height:0;}
  .footer-logo img{height:22px;width:auto;display:block;}
  footer .tagline{color:rgba(245,243,237,.6);margin-top:12px;}
  footer h4{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:rgba(255,255,255,.55);margin:0 0 16px;}
  footer ul{list-style:none;margin:0;padding:0;}
  footer li{margin-bottom:10px;font-size:16px;color:rgba(245,243,237,.85);}
  footer a:hover{color:#fff;}
  footer .contact{font-size:16px;line-height:1.7;color:rgba(245,243,237,.85);}
  .compliance{font-family:var(--serif);font-size:13px;line-height:1.6;color:rgba(245,243,237,.5);margin:30px 0;max-width:none;}
  footer .legal{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(245,243,237,.55);}
  footer .legal a{margin-left:18px;}
  footer .powered-by{margin-top:16px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:rgba(245,243,237,.5);}
  footer .powered-by em{font-style:italic;}
  footer .powered-by a{color:rgba(245,243,237,.85);font-style:normal;}
  footer .powered-by a:hover{color:#fff;text-decoration:underline;}

  /* ---------- responsive ---------- */
  @media(max-width:900px){
    body{font-size:17px;}
    .lead{grid-template-columns:1fr;gap:26px;}
    .lead-img{order:-1;max-width:460px;}
    .secondaries{grid-template-columns:1fr 1fr;gap:24px;margin-top:36px;padding-top:30px;}
    .strip ol{grid-template-columns:1fr;}
    .strip li:nth-last-child(-n+3){border-bottom:1px solid rgba(255,255,255,.14);}
    .strip li:last-child{border-bottom:0;}
    .grid{grid-template-columns:1fr 1fr;}
    .spotlight .wrap{grid-template-columns:1fr;gap:30px;}
    .tiers{grid-template-columns:1fr;}
    .signup .wrap{grid-template-columns:1fr;}
    footer .top{grid-template-columns:1fr;gap:30px;}
  }
  @media(max-width:560px){
    .wrap{padding:0 18px;}
    .grid{grid-template-columns:1fr;}
    .secondaries{grid-template-columns:1fr;}
    .masthead .wrap{padding-top:18px;padding-bottom:18px;}
    .masthead-cta{padding:12px 20px;font-size:12px;}
    .strip{padding:24px 20px;}
  }
  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;scroll-behavior:auto!important;}
  }

  /* ===================================================================
     ADDED: site-wide components for the full Eleventy build
     (article pages, archive, pagination, category headers, mobile nav,
     search dropdown, contact/advertise pages)
     =================================================================== */

  /* mobile nav toggle (hidden on desktop) */
  .navtoggle{display:none;}
  .navtoggle .ico-close{display:none;}
  .navtoggle[aria-expanded="true"] .ico-menu{display:none;}
  .navtoggle[aria-expanded="true"] .ico-close{display:block;}

  /* search results dropdown */
  .searchband .wrap{position:relative;}
  .search-results{
    position:absolute;left:28px;right:28px;
    top:calc(100% - 6px);z-index:60;
    background:var(--paper);border:1px solid var(--line);border-radius:0;
    box-shadow:0 18px 44px -20px rgba(21,23,28,.4);
    overflow:hidden;display:none;
  }
  .search-results.open{display:block;}
  .search-results a{display:flex;align-items:baseline;justify-content:space-between;gap:18px;padding:14px 18px;border-bottom:1px solid var(--line-soft);}
  .search-results a:last-child{border-bottom:0;}
  .search-results a:hover,.search-results a:focus{background:var(--shell);}
  .search-results .sr-t{flex:1;min-width:0;font-family:var(--display);font-weight:600;font-size:15px;line-height:1.3;color:var(--ink);}
  .search-results .sr-c{flex:none;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap;}
  .search-results .sr-empty{padding:16px 18px;font-family:var(--serif);color:var(--ink-soft);font-size:15px;}

  /* ---------- article page ---------- */
  .article{padding:40px 0 20px;}
  .article-wrap{max-width:760px;margin:0 auto;padding:0 28px;}
  .article .cat{margin-bottom:14px;}
  .article h1{font-family:var(--display);font-weight:800;letter-spacing:-.02em;line-height:1.03;font-size:clamp(30px,4.6vw,52px);margin:0 0 18px;}
  .article .lede{font-family:var(--serif);font-size:21px;line-height:1.5;color:var(--ink-soft);margin:0 0 22px;}
  .article .meta{display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);padding-bottom:26px;border-bottom:1px solid var(--line);}
  .article .meta .by{color:var(--ink);}
  .article-hero{max-width:620px;margin:30px auto 0;padding:0 28px;}
  .article-hero img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:0;display:block;}
  .article-hero figcaption{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-top:8px;text-align:center;}

  /* article body typography */
  .prose{font-family:var(--serif);font-size:19px;line-height:1.7;color:var(--ink);padding-top:28px;}
  .prose::after{content:"";display:block;clear:both;}
  .prose > *:first-child{margin-top:0;}
  .prose p{margin:0 0 22px;}
  .prose h2{font-family:var(--display);font-weight:700;font-size:30px;line-height:1.1;letter-spacing:-.01em;margin:40px 0 14px;}
  .prose h3{font-family:var(--display);font-weight:700;font-size:24px;line-height:1.12;margin:34px 0 12px;}
  .prose h4{font-family:var(--display);font-weight:600;font-size:20px;margin:28px 0 10px;}
  .prose a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--coral);text-underline-offset:3px;text-decoration-thickness:2px;}
  .prose a:hover{color:var(--coral-deep);}
  .prose strong{font-weight:700;}
  .prose em{font-style:italic;}
  .prose ul,.prose ol{margin:0 0 22px;padding-left:24px;}
  .prose li{margin:0 0 9px;}
  .prose blockquote{margin:28px 0;padding:6px 0 6px 22px;border-left:3px solid var(--coral);font-style:italic;font-size:22px;line-height:1.45;color:var(--ink);}
  .prose img{width:100%;height:auto;border-radius:0;display:block;}
  .prose .post-figure{
    float:right;clear:right;width:44%;margin:8px 0 20px 28px;
  }
  .prose .post-figure:nth-of-type(even){float:left;clear:left;margin:8px 28px 20px 0;}
  .prose .post-figure img{aspect-ratio:1/1;object-fit:cover;width:100%;height:auto;}
  @media(max-width:620px){
    .prose .post-figure,
    .prose .post-figure:nth-of-type(even){float:none;clear:both;width:100%;margin:24px 0;}
  }
  .prose hr{border:0;border-top:1px solid var(--line);margin:36px 0;}
  .prose iframe{width:100%;aspect-ratio:16/9;border:0;border-radius:0;margin:30px 0;}

  .article-foot{max-width:760px;margin:36px auto 0;padding:24px 28px 0;border-top:1px solid var(--line);}
  .backlink{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--coral-deep);}
  .backlink:hover{text-decoration:underline;}

  /* related */
  .related{margin-top:56px;}

  /* ---------- archive / category header ---------- */
  .archive-head{padding:44px 0 8px;border-bottom:1px solid var(--line);margin-bottom:34px;}
  .archive-head .eyebrow{color:var(--coral-deep);}
  .archive-head h1{font-family:var(--display);font-weight:800;letter-spacing:-.02em;font-size:clamp(32px,5vw,58px);margin:10px 0 8px;}
  .archive-head p{font-family:var(--serif);font-size:18px;color:var(--ink-soft);margin:0 0 20px;max-width:60ch;}

  /* pagination */
  .pager{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:48px 0 8px;padding-top:26px;border-top:1px solid var(--line);}
  .pager a,.pager span{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;}
  .pager a{padding:11px 20px;border:1px solid var(--ink);border-radius:0;color:var(--ink);transition:background .2s,color .2s;}
  .pager a:hover{background:var(--ink);color:var(--paper);}
  .pager .disabled{color:var(--ink-soft);opacity:.5;}
  .pager .count{color:var(--ink-soft);}

  /* ---------- simple content page (advertise/contact) ---------- */
  .page{padding:44px 0 30px;}
  .page-wrap{max-width:760px;margin:0 auto;padding:0 28px;}
  .page h1{font-family:var(--display);font-weight:800;letter-spacing:-.02em;font-size:clamp(30px,4.4vw,50px);margin:0 0 18px;}
  .page .prose{padding-top:8px;}
  .info-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:30px 0;}
  .info-card{background:var(--paper);border:1px solid var(--line);border-radius:0;padding:24px;}
  .info-card h3{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--coral-deep);margin:0 0 12px;}
  .info-card p{font-family:var(--serif);font-size:17px;line-height:1.6;margin:0;color:var(--ink);}

  /* advertise tiers reuse */
  .tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:30px 0;}
  .tier{background:var(--paper);border:1px solid var(--line);border-radius:0;padding:28px 24px;display:flex;flex-direction:column;}
  .tier.feat{background:var(--ink);color:var(--paper);border-color:var(--ink);}
  .tier .tname{font-family:var(--display);font-weight:700;font-size:22px;}
  .tier .tflag{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--coral);min-height:14px;margin-bottom:8px;}
  .tier .tprice{font-family:var(--display);font-weight:800;font-size:38px;letter-spacing:-.03em;margin:12px 0 2px;}
  .tier .tprice span{font-family:var(--mono);font-size:12px;font-weight:400;}
  .tier .twas{font-family:var(--mono);font-size:12px;color:var(--ink-soft);text-decoration:line-through;margin-bottom:16px;}
  .tier.feat .twas{color:rgba(255,255,255,.5);}
  .tier ul{list-style:none;margin:0 0 22px;padding:0;flex:1;}
  .tier li{font-family:var(--serif);font-size:16px;padding:8px 0;border-bottom:1px solid var(--line-soft);}
  .tier.feat li{border-color:rgba(255,255,255,.12);}

  @media(max-width:760px){
    .info-grid{grid-template-columns:1fr;}
    .tiers{grid-template-columns:1fr;}
  }

  /* ---------- mobile nav ---------- */
  @media(max-width:760px){
    .navtoggle{
      display:inline-flex;align-items:center;gap:8px;cursor:pointer;
      background:none;border:0;font-family:var(--mono);font-size:12px;
      letter-spacing:.06em;text-transform:uppercase;font-weight:600;color:var(--ink);
      padding:8px 4px;margin-left:0;
    }
    .navtoggle svg{width:22px;height:22px;}
    .navtoggle span{display:none;}
    nav.cats .wrap{justify-content:flex-start;height:auto;min-height:50px;padding-top:8px;padding-bottom:8px;flex-wrap:nowrap;gap:0 10px;}
    .navlogo{flex-basis:auto;}
    .navlogo .logo-img{height:34px;}
    .searchtoggle{margin-left:auto;}
    nav.cats .catlinks{
      display:none;position:fixed;inset:0;z-index:200;background:var(--paper);
      flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:0;
      padding:84px 28px 48px;overflow-y:auto;
    }
    nav.cats .catlinks.open{display:flex;}
    nav.cats .catlinks a{
      font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:-.01em;
      color:var(--ink);padding:11px 0;width:100%;border-bottom:1px solid var(--line-soft);text-align:left;
    }
    nav.cats a::after{display:none;}
    body.menu-open{overflow:hidden;}
    /* backdrop-filter on the nav makes it the containing block for position:fixed
       children, trapping the overlay inside the bar. Drop it while the menu is open
       so the full-screen menu anchors to the viewport. */
    body.menu-open nav.cats{-webkit-backdrop-filter:none;backdrop-filter:none;background:var(--paper);}
    body.menu-open .navtoggle{position:fixed;top:14px;right:20px;z-index:260;}
    body.menu-open .navlogo{position:fixed;top:12px;left:18px;z-index:260;}
  }

  /* ---------- Today: ambient animated backgrounds (markets + breaking) ---------- */
  .p-markets .mkt{position:relative;}
  .p-markets .mkt > *{position:relative;z-index:1;}
  .p-markets .mkt::before{content:"";position:absolute;inset:-6px 0 0;z-index:0;pointer-events:none;opacity:.6;
    background-image:repeating-linear-gradient(0deg,rgba(21,23,28,.045) 0 1px,transparent 1px 26px);
    background-size:100% 26px;animation:mktgrid 6s linear infinite;}
  @keyframes mktgrid{from{background-position:0 0;}to{background-position:0 26px;}}

  .p-breaking .brk{position:relative;}
  .p-breaking .brk > *{position:relative;z-index:1;}
  .p-breaking .brk::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.7;
    background:linear-gradient(120deg,transparent,rgba(21,23,28,.06),rgba(21,23,28,.03),transparent);
    background-size:220% 100%;animation:brksweep 5.5s linear infinite;}
  @keyframes brksweep{0%{background-position:210% 0;}100%{background-position:-210% 0;}}

  @media(prefers-reduced-motion:reduce){
    .p-markets .mkt::before,.p-breaking .brk::before{animation:none;}
  }

  /* clean photo covers: drop decorative wave texture */
  .cover::after{display:none;}

  /* ---- Events landing page ---- */
  .ev-upcoming{margin-top:8px;}
  .ev-coverage{margin-top:18px;}
  .ev-list{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
  .ev-card{display:grid;grid-template-columns:auto 1fr;gap:20px;border:1px solid var(--line);background:var(--paper);padding:22px 24px;}
  .ev-date{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:64px;padding:10px 6px;background:var(--ink);color:var(--paper);}
  .ev-date .ev-mon{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;}
  .ev-date .ev-day{font-family:var(--display);font-size:30px;line-height:1;font-weight:700;margin-top:3px;}
  .ev-body h3{font-size:20px;line-height:1.2;margin:0 0 6px;}
  .ev-meta{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);opacity:.62;margin:0 0 8px;}
  .ev-blurb{font-size:15px;line-height:1.5;margin:0 0 10px;}
  .ev-link{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;text-decoration:none;border-bottom:1px solid currentColor;padding-bottom:2px;}

  .ev-empty{border:1px solid var(--line);background:var(--shell);padding:54px 32px;text-align:center;display:flex;flex-direction:column;align-items:center;}
  .ev-empty-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--ink);opacity:.55;margin-bottom:14px;}
  .ev-empty h3{font-size:clamp(22px,2.4vw,30px);line-height:1.18;margin:0 0 12px;max-width:30ch;}
  .ev-empty p{font-size:16px;line-height:1.55;max-width:52ch;margin:0 0 24px;color:var(--ink);opacity:.78;}
  .ev-empty-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;}

  @media (max-width:680px){
    .ev-list{grid-template-columns:1fr;}
    .ev-empty{padding:40px 22px;}
  }
