:root{
  --ink:#101820;
  --paper:#FAFBFC;
  --card:#FFFFFF;
  --bib:#FF4D12;
  --bib-dark:#D63A05;
  --sky:#DCE7EE;
  --slate:#5B6770;
  --line:#E2E8EC;
  --good:#1D7A4F;
  --radius:14px;
  --display:'Anton', sans-serif;
  --body:'Archivo', sans-serif;
  --mono:'IBM Plex Mono', monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--bib);outline-offset:2px;border-radius:4px}

.wrap{max-width:1080px;margin:0 auto;padding:0 24px}

/* ---------- header ---------- */
header{
  position:sticky;top:0;z-index:20;
  background:rgba(250,251,252,.9);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:62px}
.logo{font-family:var(--display);font-size:1.35rem;letter-spacing:.04em;display:flex;align-items:center;gap:.5rem;text-transform:uppercase;text-decoration:none}
.logo .arrow{color:var(--bib)}
.nav-actions{display:flex;align-items:center;gap:12px}
.nav-cta{
  background:var(--ink);color:#fff;border:none;border-radius:999px;
  padding:.55rem 1.2rem;font-weight:600;font-size:.9rem;
}
.nav-cta:hover{background:var(--bib)}

/* ---------- hero ---------- */
.hero{padding:72px 0 56px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:start}
.eyebrow{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--bib-dark);margin-bottom:18px;display:flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--bib);display:inline-block}
h1{
  font-family:var(--display);font-weight:400;
  font-size:clamp(2.6rem, 6vw, 4.6rem);
  line-height:1.02;text-transform:uppercase;letter-spacing:.01em;
}
h1 .accent{color:var(--bib)}
.hero p.lede{margin-top:22px;font-size:1.12rem;color:var(--slate);max-width:46ch}
.hero-points{margin-top:30px;display:grid;gap:12px;max-width:46ch}
.hero-points div{display:flex;gap:12px;align-items:flex-start;font-size:.97rem}
.tick{
  flex:none;width:22px;height:22px;border-radius:50%;
  background:var(--ink);color:#fff;display:grid;place-items:center;
  font-size:.7rem;margin-top:2px;
}

/* ---------- form card ---------- */
.form-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:0 18px 44px -22px rgba(16,24,32,.25);
  padding:28px;position:relative;
}
.form-card::before{ /* safety pin notch, race-clipboard nod */
  content:"";position:absolute;top:-9px;left:50%;transform:translateX(-50%);
  width:74px;height:18px;background:var(--ink);border-radius:9px;
}
.form-card h2{font-family:var(--display);font-weight:400;font-size:1.4rem;text-transform:uppercase;letter-spacing:.03em;margin-bottom:4px}
.form-card .sub{color:var(--slate);font-size:.92rem;margin-bottom:20px}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1 / -1}
label{font-size:.8rem;font-weight:600;letter-spacing:.02em;color:var(--ink)}
label .opt{color:var(--slate);font-weight:400}
select,input[type=number],input[type=date]{
  font-family:var(--body);font-size:.95rem;color:var(--ink);
  border:1.5px solid var(--line);border-radius:10px;background:#fff;
  padding:.6rem .7rem;width:100%;
}
select:hover,input[type=number]:hover,input[type=date]:hover{border-color:#c4ced5}
.range-row{display:flex;align-items:center;gap:14px}
.range-row input[type=date]{flex:1;min-width:0}
input[type=range]{flex:1;accent-color:var(--bib)}
.date-note{font-size:.78rem;color:var(--slate);margin-top:2px}
.date-note.warn{color:var(--bib-dark);font-weight:600}
.range-val{
  font-family:var(--mono);font-weight:600;font-size:.95rem;
  min-width:88px;text-align:right;
}
.generate{
  margin-top:22px;width:100%;
  background:var(--bib);color:#fff;border:none;border-radius:12px;
  font-size:1.02rem;font-weight:700;padding:.95rem;
  letter-spacing:.02em;transition:transform .12s ease, background .12s ease;
}
.generate:hover{background:var(--bib-dark);transform:translateY(-1px)}
.generate:active{transform:translateY(0)}
.form-note{margin-top:12px;font-size:.78rem;color:var(--slate);text-align:center}

/* ---------- finish-line ribbon ---------- */
.ribbon{
  height:26px;margin-top:8px;
  background:
    repeating-conic-gradient(var(--ink) 0% 25%, #fff 0% 50%) 0 0 / 26px 26px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  opacity:.9;
}

/* ---------- results ---------- */
#plan{padding:64px 0 30px;display:none}
#plan.show{display:block;animation:rise .45s ease}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.plan-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:30px}
.plan-head h2{font-family:var(--display);font-weight:400;font-size:clamp(1.8rem,4vw,2.6rem);text-transform:uppercase;line-height:1.05}
.plan-head .meta{font-family:var(--mono);font-size:.82rem;color:var(--slate)}
.print-btn{
  background:#fff;border:1.5px solid var(--ink);border-radius:999px;
  padding:.5rem 1.1rem;font-weight:600;font-size:.88rem;
}
.print-btn:hover{background:var(--ink);color:#fff}
.method-line{font-size:.82rem;color:var(--slate);margin-top:6px}
.method-line a{color:var(--bib-dark)}

/* plan-level notes (compressed timeline, modifiers, progression) */
.plan-notes{display:grid;gap:10px;margin:-12px 0 24px}
.plan-notes:empty{display:none}
.plan-notes .note{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  background:#fff;border:1px solid var(--line);border-left:4px solid var(--sky);
  border-radius:10px;padding:10px 14px;font-size:.86rem;color:var(--slate);
}
.plan-notes .note.warn{
  border-color:var(--bib);border-left-width:4px;background:#FFF3ED;
  color:var(--ink);font-weight:500;
}

.plan-grid{display:grid;grid-template-columns:300px 1fr;gap:28px;align-items:start}

/* race bib */
.bib{
  background:#fff;border:2px solid var(--ink);border-radius:10px;
  padding:18px 18px 20px;text-align:center;position:relative;
  box-shadow:0 14px 30px -18px rgba(16,24,32,.35);
}
.bib::before,.bib::after,
.bib .pin-l,.bib .pin-r{
  content:"";position:absolute;width:10px;height:10px;border-radius:50%;
  background:var(--paper);border:2px solid var(--ink);
}
.bib::before{top:8px;left:8px}
.bib::after{top:8px;right:8px}
.bib .pin-l{bottom:8px;left:8px}
.bib .pin-r{bottom:8px;right:8px}
.bib .race-name{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  border-bottom:2px solid var(--ink);padding-bottom:8px;margin:4px 14px 6px;
}
.bib .number{
  font-family:var(--display);font-size:4.6rem;line-height:1;color:var(--ink);
  letter-spacing:.02em;
}
.bib .number-label{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bib-dark);margin-top:2px}
.bib .strip{
  margin:14px -2px -2px;background:var(--bib);color:#fff;border-radius:0 0 8px 8px;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;
  padding:7px 0;
}
.stat-list{margin-top:18px;display:grid;gap:10px}
.stat{
  background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:12px 14px;display:flex;justify-content:space-between;align-items:baseline;gap:10px;
}
.stat b{font-family:var(--mono);font-size:1.05rem}
.stat span{font-size:.82rem;color:var(--slate)}

/* chart */
.chart-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 22px 14px;
}
.chart-card h3{font-family:var(--display);font-weight:400;font-size:1.15rem;text-transform:uppercase;letter-spacing:.03em}
.chart-card .sub{font-size:.86rem;color:var(--slate);margin-bottom:14px}
.legend{display:flex;flex-wrap:wrap;gap:16px;margin-top:8px;font-family:var(--mono);font-size:.72rem;color:var(--slate)}
.legend i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:6px;vertical-align:-1px}
svg .bar{transition:opacity .15s}
svg .bar:hover{opacity:.75}

/* weeks */
.weeks{margin-top:28px;display:grid;gap:12px}
details.week{
  background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;
}
details.week[open]{border-color:var(--ink)}
details.week summary{
  list-style:none;display:flex;align-items:center;gap:16px;
  padding:14px 18px;cursor:pointer;flex-wrap:wrap;
}
details.week summary::-webkit-details-marker{display:none}
.wk-num{
  font-family:var(--display);font-size:1.05rem;min-width:74px;
  text-transform:uppercase;letter-spacing:.02em;
}
.wk-tag{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.25rem .6rem;border-radius:999px;border:1px solid currentColor;
}
.tag-build{color:var(--bib-dark)}
.tag-cutback{color:var(--good)}
.tag-peak{color:var(--ink)}
.tag-taper{color:#3A6BB5}
.tag-race{color:#fff;background:var(--bib);border-color:var(--bib)}
.wk-miles{margin-left:auto;font-family:var(--mono);font-size:.88rem;color:var(--slate)}
.wk-caret{transition:transform .2s;color:var(--slate)}
details[open] .wk-caret{transform:rotate(180deg)}
.day-grid{
  display:grid;grid-template-columns:repeat(7,1fr);gap:8px;
  padding:0 18px 18px;
}
.day{
  border:1px solid var(--line);border-radius:8px;padding:10px 10px 12px;
  font-size:.8rem;min-height:88px;background:var(--paper);position:relative;
}
.day .d-name{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);margin-bottom:6px}
.day .d-date{color:#9AA6AE;letter-spacing:.05em}
.day .d-type{font-weight:700;font-size:.82rem}
.day .d-detail{color:var(--slate);margin-top:3px;font-size:.76rem;line-height:1.35}
.day.run{background:#fff;border-color:#F3C9B8}
.day.key{background:#FFF3ED;border-color:var(--bib)}
.day.race-day{background:var(--ink);color:#fff;border-color:var(--ink)}
.day.race-day .d-name,.day.race-day .d-detail{color:#cfd6db}

/* completion tracking */
.done-box{
  display:flex;align-items:center;gap:6px;margin-top:8px;width:max-content;
  font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--slate);cursor:pointer;
}
.done-box input{accent-color:var(--bib);width:14px;height:14px;margin:0;cursor:pointer;flex:none}
.day.race-day .done-box{color:#cfd6db}
.cal-cell .done-box{margin-top:auto;gap:4px;font-size:.54rem}
.cal-cell .done-box input{width:12px;height:12px}
.cal-cell.race-day .done-box{color:#cfd6db}
.wk-done{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--slate);border:1px solid currentColor;border-radius:999px;padding:.25rem .6rem;
}
.wk-done.all{color:var(--good)}

/* restored-plan note */
.restore-note{
  display:inline-block;margin-bottom:18px;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;color:var(--good);
  background:#EAF6F0;border:1px solid #BFE3D0;border-radius:999px;padding:.45rem .95rem;
}
.restore-note[hidden]{display:none}

/* strength chip on rest days */
.chip{
  display:inline-block;font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;
  text-transform:uppercase;background:var(--sky);color:var(--ink);
  border-radius:999px;padding:.15rem .55rem;margin-top:4px;
}

/* ---------- "why" buttons + research popover ---------- */
.why-btn{
  width:18px;height:18px;border-radius:50%;border:1.5px solid var(--slate);
  background:#fff;color:var(--slate);font-family:var(--mono);font-size:.62rem;
  font-weight:600;line-height:1;display:inline-grid;place-items:center;
  padding:0;flex:none;font-style:italic;
}
.why-btn:hover,.why-btn[aria-expanded="true"]{
  border-color:var(--bib);color:var(--bib-dark);background:#FFF3ED;
}
.day .why-btn{position:absolute;top:8px;right:8px}
.day.race-day .why-btn{background:transparent;color:#cfd6db;border-color:#5B6770}
details.week summary .why-btn{margin-left:2px}
.why-pop{
  position:absolute;z-index:80;max-width:340px;background:#fff;
  border:2px solid var(--ink);border-radius:12px;padding:14px 16px;
  box-shadow:0 18px 40px -18px rgba(16,24,32,.4);
  font-size:.84rem;line-height:1.5;
}
.why-pop .why-title{
  font-family:var(--display);font-weight:400;font-size:.95rem;
  text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px;
}
.why-pop .why-text{color:var(--slate);max-height:220px;overflow:auto}
.why-pop .why-cites{margin-top:10px;font-family:var(--mono);font-size:.7rem;letter-spacing:.04em}
.why-pop .why-cites a{color:var(--bib-dark)}
.why-pop .dot{margin:0 6px;color:var(--slate)}
.why-pop .why-foot{margin-top:8px;font-size:.72rem}
.why-pop .why-foot a{color:var(--slate)}

/* ---------- training calendar ---------- */
.cal-card{
  margin-top:28px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;
}
.cal-head h3{font-family:var(--display);font-weight:400;font-size:1.15rem;text-transform:uppercase;letter-spacing:.03em}
.cal-head .sub{font-size:.86rem;color:var(--slate);margin-bottom:6px}
.cal-month{margin-top:18px}
.cal-month h3{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--bib-dark);margin-bottom:10px;
}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal-dow{
  font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--slate);text-align:center;padding-bottom:4px;
}
.cal-cell{
  border:1px solid var(--line);border-radius:8px;min-height:58px;
  padding:6px 7px;background:var(--paper);position:relative;font-size:.72rem;
  display:flex;flex-direction:column;gap:2px;
}
.cal-cell.off{background:transparent;border-color:transparent;color:#b7c0c6}
.cal-cell .cal-num{font-family:var(--mono);font-size:.68rem;color:var(--slate)}
.cal-cell.off .cal-num{color:#b7c0c6}
.cal-cell .cal-type{font-weight:700;font-size:.7rem;line-height:1.2}
.cal-cell.run{background:#fff;border-color:#F3C9B8}
.cal-cell.key{background:#FFF3ED;border-color:var(--bib)}
.cal-cell.race-day{background:var(--ink);color:#fff;border-color:var(--ink)}
.cal-cell.race-day .cal-num{color:#cfd6db}
.cal-cell.today{outline:2px solid var(--bib);outline-offset:1px}

/* clickable done-tracking days */
[data-doneday]{cursor:pointer}
.day.done,.cal-cell.done{background:#E9F6EE;border-color:#8FCDAE}
.day.done .d-type,.cal-cell.done .cal-type{color:var(--good)}
.day.race-day.done,.cal-cell.race-day.done{background:var(--good);border-color:var(--good);color:#fff}
.day.race-day.done .d-name,.day.race-day.done .d-detail,.cal-cell.race-day.done .cal-num{color:#d6ece0}
.cal-help{font-size:.82rem;color:var(--slate);margin-top:6px;max-width:72ch}

/* race-day celebration card */
.race-cheer{
  margin-top:28px;position:relative;display:flex;gap:18px;align-items:flex-start;
  background:linear-gradient(135deg,#E9F6EE 0%,#FFF3ED 100%);
  border:2px solid var(--good);border-radius:var(--radius);padding:24px 48px 24px 24px;
}
.race-cheer-medal{font-size:2.4rem;line-height:1;flex:none}
.race-cheer h3{font-family:var(--display);font-weight:400;font-size:1.25rem;text-transform:uppercase;letter-spacing:.03em;margin-bottom:8px}
.race-cheer p{font-size:.92rem;color:var(--ink);max-width:64ch;margin-bottom:14px}
.race-cheer-btn{
  display:inline-block;background:var(--good);color:#fff;text-decoration:none;
  border-radius:999px;padding:.6rem 1.3rem;font-weight:700;font-size:.92rem;
}
.race-cheer-btn:hover{background:var(--ink)}
.race-cheer-close{
  position:absolute;top:10px;right:12px;background:none;border:none;
  font-size:1.3rem;color:var(--slate);line-height:1;padding:4px;
}
.race-cheer-close:hover{color:var(--ink)}

.pace-card{
  margin-top:28px;background:var(--sky);border-radius:var(--radius);
  padding:24px 26px;display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px;
}
.pace-card h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px;color:var(--bib-dark)}
.pace-card p{font-size:.88rem;color:var(--ink)}

.disclaimer{margin:26px 0 0;font-size:.78rem;color:var(--slate);max-width:72ch}

/* ---------- how it works ---------- */
.how{padding:64px 0;border-top:1px solid var(--line);margin-top:56px}
.how h2{font-family:var(--display);font-weight:400;font-size:1.9rem;text-transform:uppercase;margin-bottom:30px}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.how-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.how-card .mile{
  font-family:var(--display);color:var(--bib);font-size:1.5rem;margin-bottom:10px;
}
.how-card h3{font-size:1rem;margin-bottom:6px}
.how-card p{font-size:.88rem;color:var(--slate)}

/* ---------- static pages (about, privacy, terms, contact) ---------- */
.page{padding:64px 0 80px;max-width:760px;margin:0 auto}
.page h1{font-size:clamp(2rem,5vw,3rem);margin-bottom:8px}
.page .updated{font-family:var(--mono);font-size:.78rem;color:var(--slate);margin-bottom:34px}
.page h2{font-family:var(--display);font-weight:400;font-size:1.3rem;text-transform:uppercase;letter-spacing:.03em;margin:34px 0 10px}
.page p,.page li{color:var(--slate);font-size:.97rem;margin-bottom:12px}
.page ul{padding-left:22px;margin-bottom:12px}
.page a{color:var(--bib-dark)}
.page strong{color:var(--ink)}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:26px 0;margin-top:30px}
footer .wrap{display:flex;flex-direction:column;gap:14px;font-size:.82rem;color:var(--slate)}
.footer-links{display:flex;flex-wrap:wrap;gap:8px 22px}
.footer-links a{text-decoration:none}
.footer-links a:hover{color:var(--bib-dark);text-decoration:underline}
.footer-meta{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}

@media (max-width: 900px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .plan-grid{grid-template-columns:1fr}
  .bib{max-width:320px;margin:0 auto}
  .how-grid{grid-template-columns:1fr}
  .day-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width: 600px){
  /* keep the header on one line once the auth UI renders — the hero form
     sits directly below, so hiding the CTA is safe */
  .nav-cta{display:none}
  .account-name{max-width:70px}
}
@media (max-width: 560px){
  .field-grid{grid-template-columns:1fr}
  .day-grid{grid-template-columns:1fr}
  .wk-miles{margin-left:0;width:100%}
  .cal-grid{gap:3px}
  .cal-cell{min-height:44px;padding:4px 4px}
  .cal-cell .cal-type{font-size:.56rem}
}
/* ---------- account (sign-in, plans, sync) ---------- */
.gsi-host{display:flex;align-items:center;min-height:32px}
.account{position:relative}
.account-chip{
  display:flex;align-items:center;gap:8px;
  background:#fff;border:1.5px solid var(--line);border-radius:999px;
  padding:.3rem .85rem .3rem .4rem;font-weight:600;font-size:.85rem;color:var(--ink);
}
.account-chip:hover{border-color:var(--ink)}
.account-pic{width:24px;height:24px;border-radius:50%;flex:none;object-fit:cover}
.account-name{max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.account-menu{
  position:absolute;right:0;top:calc(100% + 8px);z-index:60;min-width:200px;
  background:#fff;border:2px solid var(--ink);border-radius:12px;padding:6px;
  box-shadow:0 18px 40px -18px rgba(16,24,32,.4);
}
.account-menu-id{
  font-family:var(--mono);font-size:.68rem;color:var(--slate);
  padding:6px 10px 8px;border-bottom:1px solid var(--line);margin-bottom:4px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.account-item{
  display:block;width:100%;text-align:left;background:none;border:none;
  border-radius:8px;padding:.5rem .7rem;font-size:.88rem;font-weight:500;color:var(--ink);
}
.account-item:hover{background:var(--paper);color:var(--bib-dark)}
.account-item.danger{color:var(--bib-dark)}
.account-item.danger:hover{background:#FFF3ED}

#accountUI{padding:32px 0 0}
.account-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:0 18px 44px -22px rgba(16,24,32,.25);padding:24px 26px;
}
.account-card-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}
.account-card-head h2{font-family:var(--display);font-weight:400;font-size:1.3rem;text-transform:uppercase;letter-spacing:.03em}
.account-close{
  background:#fff;border:1.5px solid var(--line);border-radius:50%;
  width:30px;height:30px;font-size:1rem;line-height:1;color:var(--slate);
}
.account-close:hover{border-color:var(--ink);color:var(--ink)}
.plans-status{font-size:.9rem;color:var(--slate)}
.plans-list{list-style:none;display:grid;gap:10px}
.plan-row{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px 16px;
  border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:var(--paper);
}
.plan-row-main{display:flex;flex-direction:column;gap:2px;min-width:0}
.plan-row-name{font-weight:700;font-size:.95rem;overflow:hidden;text-overflow:ellipsis}
.plan-row-meta{font-family:var(--mono);font-size:.72rem;color:var(--slate)}
.plan-row-actions{display:flex;gap:8px;flex:none}
.plan-open,.plan-delete{
  border-radius:999px;font-weight:600;font-size:.8rem;padding:.4rem .95rem;
}
.plan-open{background:var(--ink);color:#fff;border:1.5px solid var(--ink)}
.plan-open:hover{background:var(--bib);border-color:var(--bib)}
.plan-delete{background:#fff;color:var(--bib-dark);border:1.5px solid var(--line)}
.plan-delete:hover{border-color:var(--bib-dark)}

.save-inline{
  background:#fff;border:1.5px solid var(--bib);color:var(--bib-dark);
  border-radius:999px;padding:.5rem 1.1rem;font-weight:600;font-size:.88rem;
}
.save-inline:hover{background:var(--bib);color:#fff}
.save-inline[hidden]{display:none}

.import-banner{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px 18px;
  background:#FFF3ED;border-bottom:1px solid var(--bib);
  padding:10px 24px;font-size:.88rem;color:var(--ink);
}
.import-actions{display:flex;gap:8px}
.import-yes,.import-no{border-radius:999px;font-weight:600;font-size:.8rem;padding:.35rem .9rem}
.import-yes{background:var(--bib);color:#fff;border:1.5px solid var(--bib)}
.import-yes:hover{background:var(--bib-dark);border-color:var(--bib-dark)}
.import-no{background:#fff;color:var(--slate);border:1.5px solid var(--line)}
.import-no:hover{border-color:var(--slate)}

.toast{
  position:fixed;left:50%;bottom:24px;transform:translate(-50%,12px);z-index:90;
  background:var(--ink);color:#fff;border-radius:999px;padding:.6rem 1.2rem;
  font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;
  box-shadow:0 14px 30px -14px rgba(16,24,32,.5);
  opacity:0;pointer-events:none;transition:opacity .25s ease, transform .25s ease;
}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* printed title line (hidden on screen) */
.print-title{display:none}

@media print{
  header,.hero,.how,footer,.print-btn,.ribbon,
  .why-btn,.why-pop,#authArea,#accountUI,.restore-note,.wk-done,
  .toast,.import-banner,.save-inline,.race-cheer,.cal-help{display:none!important}
  #plan{padding-top:0}
  .print-title{
    display:block;font-family:var(--display);font-size:1.4rem;
    text-transform:uppercase;letter-spacing:.02em;
    border-bottom:3px solid var(--ink);padding-bottom:6px;margin-bottom:14px;
  }
  details.week{break-inside:avoid}
  .cal-month{break-inside:avoid;page-break-inside:avoid}
}
