@font-face{font-family:"Puffin Transit";src:url("./fonts/woff2/PuffinTransit-Regular.woff2") format("woff2"),url("./fonts/woff/PuffinTransit-Regular.woff") format("woff");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Puffin Transit";src:url("./fonts/woff2/PuffinTransit-Italic.woff2") format("woff2"),url("./fonts/woff/PuffinTransit-Italic.woff") format("woff");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Puffin Transit";src:url("./fonts/woff2/PuffinTransit-SemiBold.woff2") format("woff2"),url("./fonts/woff/PuffinTransit-SemiBold.woff") format("woff");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Puffin Transit";src:url("./fonts/woff2/PuffinTransit-SemiBoldItalic.woff2") format("woff2"),url("./fonts/woff/PuffinTransit-SemiBoldItalic.woff") format("woff");font-weight:600;font-style:italic;font-display:swap}
@font-face{font-family:"Puffin Transit";src:url("./fonts/woff2/PuffinTransit-Bold.woff2") format("woff2"),url("./fonts/woff/PuffinTransit-Bold.woff") format("woff");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Puffin Transit";src:url("./fonts/woff2/PuffinTransit-BoldItalic.woff2") format("woff2"),url("./fonts/woff/PuffinTransit-BoldItalic.woff") format("woff");font-weight:700;font-style:italic;font-display:swap}
@font-face{font-family:"Puffin Transit";src:url("./fonts/woff2/PuffinTransit-ExtraBold.woff2") format("woff2"),url("./fonts/woff/PuffinTransit-ExtraBold.woff") format("woff");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:"Puffin Transit";src:url("./fonts/woff2/PuffinTransit-ExtraBoldItalic.woff2") format("woff2"),url("./fonts/woff/PuffinTransit-ExtraBoldItalic.woff") format("woff");font-weight:800;font-style:italic;font-display:swap}
@font-face{font-family:"Puffin Transit";src:url("./fonts/woff2/PuffinTransit-ExtraBold.woff2") format("woff2"),url("./fonts/woff/PuffinTransit-ExtraBold.woff") format("woff");font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:"Puffin Transit";src:url("./fonts/woff2/PuffinTransit-ExtraBoldItalic.woff2") format("woff2"),url("./fonts/woff/PuffinTransit-ExtraBoldItalic.woff") format("woff");font-weight:900;font-style:italic;font-display:swap}


:root{ --fontstack: "Puffin Transit","PuffinTransit","Puffin-Transit", system-ui, -apple-system, "Segoe UI", Roboto, Inter, Arial, sans-serif;
 --cranberry: #ffe6bf;--cranberry-50:#FDEAED;--cranberry-100:#FBD6DB;--pumpkin:#D96C00;--pumpkin-50:#FFE8CF;--cream:#FFF6EA;--pink:#FFDCE5;
 --text:#7A4032;--shadow:rgba(0,0,0,.08);--page-w:1080px;--safe:72px;--radius:28px }
*{box-sizing:border-box}body{margin:0;overflow-x:hidden;background: radial-gradient(120% 100% at 50% 0%, #FFF9F0 0%, #FFE8C8 60%, #FFD8A8 100%)}
html{overflow-x:hidden}
.story{position:relative;width:100%;max-width:var(--page-w);min-height:100svh;margin:0 auto;overflow:visible;
  font-family: var(--fontstack);
  color:#b2462c
}
.story::before,.story::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.06;
  background-image:none}
.safe{position:relative;padding:var(--safe);display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:auto auto 1fr;min-height:0}
.topnav{display:flex;align-items:center;justify-content:space-between;padding-top:0}
.topnav-logo{display:block;height:40px;width:auto}
.lang-link{font-size:18px;font-weight:600;color:#b2462c;text-decoration:underline}
.lang-link:hover{opacity:0.7}
.card{background: linear-gradient(160deg, #1fa9b3 0%, #076878 100%); color:white; margin-bottom:40px; border-radius:40px;padding:40px 40px 40px 40px;box-shadow:0 18px 40px var(--shadow);position:relative;overflow:visible}
.header,.footer{display:flex;align-items:center;justify-content:space-between; padding-top:20px;gap:16px}
.header{padding-top:60px}
.header-title-block{flex:1;text-align:center;padding:0 0 16px}
.header-main-title{font-size:clamp(52px,6vw,72px);font-weight:800;color:#b2462c;margin:24px 0 18px;line-height:1.0;letter-spacing:-0.02em}
.header-subtitle{font-size:22px;color:#b2462c;opacity:1;margin:0;font-weight:500;line-height:1.5}
.header-img{display:block;margin:48px auto 28px;height:auto;max-width:min(100%,680px);width:100%}
.header-back{flex-shrink:0}
.back-link{font-size:22px;font-weight:600;color:#b2462c;text-decoration:none}
.back-link:hover{text-decoration:underline}
.landing .footer,.footer-agency{justify-content:center;padding-top:48px}
.landing .footer .brand,.footer-agency .brand{padding-top:0;align-items:center}
.footer img {display:block; margin-top:-20px;}
.header .date{font-size:24px;opacity:.8}
.footer .brand{display:flex;align-items:center;gap:10px;font-size:24px;color:var(--cranberry); padding-top: 20px; font-weight:600}
.display{font-weight:700;line-height:1;letter-spacing:-0.02em; margin-bottom:16px; font-size:clamp(22px,4.75vw,58px)}
.body{font-size:clamp(28px,3.1vw,28px);line-height:1.4}
.body b{font-weight:600}
.lead{font-size:22px}
.note-bubble{background:#fff;border-radius:36px;padding:40px 44px;box-shadow:0 10px 30px var(--shadow);position:relative}
.note-bubble::after{content:"";position:absolute;top:40px;left:-13px;width:20px;height:31px;background:#fff;filter:drop-shadow(-4px 0 6px var(--shadow));-webkit-mask:url(./assets/bubble-tip.svg?v=2) no-repeat center/100% 100%;mask:url(./assets/bubble-tip.svg?v=2) no-repeat center/100% 100%}
.sticker{position:absolute;top:-20px;right:-20px;background:#fff;border-radius:16px;transform:rotate(6deg);padding:14px 18px;font-weight:800;color:#b2462c;box-shadow:0 14px 30px var(--shadow);font-size:28px;display:inline-flex;align-items:center;gap:10px;line-height:1;width:max-content;white-space:nowrap}
.stream-wrap{position:relative;display:grid;grid-template-rows:auto 1fr auto;gap:18px;min-height:0}
.stream{overflow:visible;padding-right:0;display:grid;gap:26px;min-height:0}
/* Extra right padding so the download button has breathing room on the right edge */
.message{position:relative;padding:28px 120px 28px 30px}
.message .quote{font-weight:600;font-size:clamp(18px,2vw,24px);line-height:1.4;letter-spacing:-0.01em;white-space:pre-wrap}
.stream-count{font-size:27px;font-weight:700;color:#b2462c;padding:0 0 8px;text-align:center}
.stream-exports{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:6px;flex-wrap:wrap}
.stream-export-link{font-size:14px;font-weight:600;color:#b2462c;text-decoration:underline;opacity:.7;cursor:pointer}
.stream-export-link:hover{opacity:1}
.stream-export-link.disabled{opacity:.35;pointer-events:none;text-decoration:none}
.stream-export-sep{font-size:14px;color:#b2462c;opacity:.3}
.message .attrib{margin-top:10px;font-size:20px;text-align:left;opacity:.65;font-weight:500}
.message .attrib-aka{font-size:16px;text-align:left;opacity:.45;font-weight:500;font-style:italic;margin-top:2px;margin-left:1.05em}
.agency{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:#b15a442e;color:#b2462c;padding:14px 16px;border-radius:999px;font-weight:600;font-size:18px;text-align:center}
.footer-agency{justify-content:center}
.landing{display:grid;grid-template-rows:auto auto auto;gap:18px;min-height:0; margin-top:24px}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;overflow:visible;min-height:0}
.tile{display:flex;flex-direction:row;align-items:flex-start;justify-content:space-between;gap:16px;background:#fff;border-radius:24px;padding:24px 28px;box-shadow:0 10px 30px var(--shadow);text-decoration:none;color:inherit}
.tile-info{display:flex;flex-direction:column;gap:4px;min-width:0}
.tile h3{margin:0;font-size:32px;letter-spacing:-0.02em;overflow-wrap:anywhere;word-break:break-word;font-weight:700;line-height:1.15}
.tile .area{font-size:22px;font-weight:500;opacity:0.6}
.tile .count{opacity:1;font-size:17px;font-weight:600;text-align:right;flex-shrink:0;align-self:flex-end}
.search{width:100%;padding:18px 32px;border-radius:40px; border: 2px solid #fff4ebe8; background-color: #fff4ebe8; font-family: "Puffin Transit"; color:#065e6c; font-size:26px}
.search::placeholder{color:rgba(6,94,108,0.8)}
.search:focus{outline:none;border-color:#065e6c}
input::placeholder {color:#b2462c;}
.card a {color:#ffd0b5;}
.brand a {color: #b2462c;}
.intro {margin-top: 24px; padding-top:0px; padding-bottom:24px}
.footer {padding-top:48px;}

/* Download button styles */
.download-btn-wrap{
  position:absolute;
  top:24px;
  right:24px;
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-end;
}
.download-btn-wrap-single{
  top:50%;
  transform:translateY(-50%);
}
.download-btn {
  position:relative;
  transform:none;
  background:transparent;
  border:none;
  border-radius:0;
  cursor:pointer;
  font-size:24px;
  width:auto;
  height:auto;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#b2462c;
  font-weight:600;
  gap:4px;
  transition:opacity 0.2s;
  outline:none;
}
.download-btn-single .download-emoji{
  font-size:48px;
}
.download-btn .download-emoji{
  font-size:40px;
  line-height:1;
}
.download-btn .download-icon{width:28px;height:28px;flex-shrink:0}
.download-btn .download-index{
  font-size:20px;
  line-height:1;
}
.download-btn:hover,
.download-btn:focus-visible{
  opacity:1;
  outline:none;
}


@media (max-width: 900px){.grid{grid-template-columns:1fr}}
.hidden{display:none}
[data-prefers-agency-route] #landing-screen{display:none}
[data-prefers-agency-route] #agency-screen.hidden{display:grid}
.btn{display:inline-flex;align-items:center;gap:10px;background:#fff;border:2px solid var(--cranberry-100);color:var(--cranberry);padding:12px 16px;border-radius:12px;font-weight:800;cursor:pointer}
.back{background:#b2462c;color:#fff;border:none}
.sticker-logo{height:1.25em;width:auto;display:block}

@media (max-width: 520px){
  :root{ --safe:24px }
  .sticker{display:none}
  .header-main-title{font-size:44px}
  .header .date{display:none}
  .story{overflow:hidden}
  /* Respect iOS safe areas and force symmetric side padding using the larger inset */
  .safe{
    --sap-left:env(safe-area-inset-left, 0px);
    --sap-right:env(safe-area-inset-right, 0px);
    --sap-max:max(var(--sap-left), var(--sap-right));
    --mobile-pad:calc(var(--safe) + var(--sap-max));
    padding-top:var(--safe);
    padding-bottom:var(--safe);
    padding-left:var(--mobile-pad);
    padding-right:var(--mobile-pad);
  }
  .landing,.grid,.card,.tile{min-width:0}
  /* Slightly reduce type sizes for small screens for better fit */
  .display{font-size:clamp(40px,8vw,72px)}
  .body{font-size:clamp(22px,4.5vw,34px)}
  .lead{font-size:clamp(18px,3.8vw,24px)}
  /* Match attribution size to message text on small screens */
  .message .attrib{font-size:clamp(18px,3.8vw,28px)}
  /* Make footer controls more compact and consistent on small screens */
  .footer .brand{font-size:18px}
  .agency{font-size:16px;padding:12px 14px}
  /* Force landing tiles to respect viewport width for equal gutters */
  .landing > .card{
    width:calc(100vw - (var(--mobile-pad) * 2));
    margin-left:0;
    margin-right:0;
    padding:24px 22px;
    padding-top:66px;
    text-align:center;
  }
  .landing > .card .sticker{
    display:inline-flex;
    position:absolute;
    top:-20px;
    left:50%;
    transform:translateX(-50%) rotate(6deg);
    margin:0;
    white-space:nowrap;
  }
  .landing > .grid{
    padding-left:0;
    padding-right:0;
  }
  .grid .tile{
    width:calc(100vw - (var(--mobile-pad) * 2));
    margin-left:0;
    margin-right:0;
  }
  /* Fix stream width explicitly to bypass Safari grid sizing bugs with overflow:visible */
  #agency-screen .stream{
    width:calc(100vw - var(--mobile-pad) * 2);
    min-width:0;
    box-sizing:border-box;
  }
  /* Agency stream bubbles: fill available width */
  #agency-screen .note-bubble,
  #agency-screen .message{
    width:100%;
    box-sizing:border-box;
    margin-left:0;
    margin-right:0;
  }
  .stream-wrap .card{padding:24px 22px;width:calc(100vw - var(--mobile-pad) * 2);min-width:0;box-sizing:border-box}
  #agency-screen .footer-agency,
  .landing .footer{padding-left:24px;padding-right:24px;box-sizing:border-box;overflow:hidden}
  #agency-screen .footer-agency .brand,
  .landing .footer .brand{gap:16px !important}
  #agency-screen .footer-agency .brand img,
  .landing .footer .brand img{flex-shrink:1;min-width:0;max-height:40px;width:auto}
  .stream-wrap .tile{padding:20px 22px}
  .note-bubble{padding:32px 26px}
  .message{padding:24px 22px}
  .note-bubble.message{display:flex;flex-wrap:wrap;align-items:flex-end}
  .note-bubble.message .quote{flex-basis:100%}
  .note-bubble.message .attrib{flex:1;margin-top:10px}
  .note-bubble.message .download-btn-wrap{position:static;top:auto;right:auto;transform:none;flex-shrink:0;margin-top:10px}
  .tile{padding:20px 22px}
  .tile h3{font-size:clamp(22px,6.5vw,32px)}
  .tile .area{font-size:clamp(14px,3.5vw,20px)}
  .tile .count{font-size:clamp(14px,3.8vw,20px)}
}

/* Tag filter banner */
.tag-filter-banner{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:10px 20px;
  margin:0 auto 12px;
  max-width:600px;
  background:rgba(255,255,255,0.12);
  border-radius:12px;
  font-size:15px;
  color:rgba(255,255,255,0.85);
  letter-spacing:0.02em;
}
.tag-filter-label{font-weight:600}
.tag-filter-clear{
  color:rgba(255,255,255,0.5);
  text-decoration:none;
  font-size:13px;
  padding:2px 6px;
  border-radius:4px;
}
.tag-filter-clear:hover{
  color:#fff;
  background:rgba(255,255,255,0.15);
}

/* Route Badges (inline colored pills in intro copy) */
.route-badge{display:inline-flex;align-items:center;justify-content:center;
  padding:3px 6px;border-radius:8px;
  font-weight:700;font-size:0.875rem;line-height:0.8;
  text-transform:uppercase;max-width:fit-content;gap:0.25rem;
  vertical-align:-0.08em;
  font-family:system-ui,-apple-system,sans-serif;white-space:nowrap}

/* Export Tooltip */
.export-tooltip{position:fixed;bottom:24px;right:24px;z-index:999;background:#fff;border-radius:20px;
  padding:20px;box-shadow:0 12px 40px rgba(0,0,0,.15);width:220px;
  font-family:var(--fontstack);color:var(--text);
  animation:tooltipSlideIn .35s ease-out both}
.export-tooltip.hidden{display:none}
@keyframes tooltipSlideIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.export-tooltip-close{position:absolute;top:8px;right:10px;background:none;border:none;font-size:20px;
  cursor:pointer;color:var(--text);opacity:.5;line-height:1;padding:4px}
.export-tooltip-close:hover{opacity:1}
.export-tooltip-preview{margin-bottom:14px;text-align:center}
.export-tooltip-preview canvas{width:72px;height:128px;border-radius:8px;border:1px solid var(--cranberry-100)}
.export-tooltip-links{display:flex;flex-direction:column;gap:8px}
.export-tooltip-link{display:block;text-align:center;padding:8px 10px;border-radius:10px;
  background:var(--cream);color:var(--cranberry);font-weight:700;font-size:13px;
  text-decoration:none;cursor:pointer;transition:background .15s}
.export-tooltip-link:hover{background:var(--pink)}
.export-tooltip-link.disabled{opacity:.4;pointer-events:none;background:#eee;color:#999}
.export-tooltip-status{margin-top:10px;font-size:11px;text-align:center;opacity:.6}
@media(max-width:520px){
  .export-tooltip{bottom:12px;right:12px;width:190px;padding:16px}
  .export-tooltip-preview canvas{width:56px;height:100px}
  .export-tooltip-link{font-size:12px;padding:7px 8px}
}

/* Export progress modal */
.export-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;
  align-items:center;justify-content:center;z-index:9999;
  animation:exportModalIn .2s ease-out both}
@keyframes exportModalIn{from{opacity:0}to{opacity:1}}
.export-modal{background:#fff;border-radius:20px;padding:32px 28px;width:340px;max-width:90vw;
  box-shadow:0 12px 48px rgba(0,0,0,.18);
  animation:exportModalSlideIn .2s ease-out both}
@keyframes exportModalSlideIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.export-modal__title{margin:0 0 22px;font-size:18px;font-weight:700;color:var(--text);
  font-family:var(--fontstack)}
.export-modal__bar-track{background:#f0eae6;border-radius:99px;height:8px;overflow:hidden;margin-bottom:12px}
.export-modal__bar-fill{height:100%;background:linear-gradient(90deg,#b2462c,#e8693a);
  border-radius:99px;width:0%;transition:width .4s ease}
.export-modal__status{margin:0 0 4px;font-size:12px;color:var(--text);opacity:.65;
  font-family:var(--fontstack);min-height:16px}
.export-modal__eta{margin:0;font-size:12px;color:var(--text);opacity:.4;
  font-family:var(--fontstack);min-height:16px}
