/* Roadbook v13.29 · extracted from public/index.html */
:root{
  --safe-top:env(safe-area-inset-top,0px);
  --safe-right:env(safe-area-inset-right,0px);
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --safe-left:env(safe-area-inset-left,0px);
  --app:min(100vw,430px);
  --font:-apple-system,BlinkMacSystemFont,"SF Pro Text","SF Pro Display","Inter","Segoe UI",Roboto,Arial,sans-serif;
  --tap:48px;
  --ease:cubic-bezier(.2,.8,.2,1);
}

html[data-theme="day"]{
  --bg:#f4efe4;--surface:#fffdf7;--surface-2:#ede4d6;
  --ink:#1e1a15;--text:#2d261d;--muted:#756b5d;--soft:#9a9183;
  --line:rgba(30,26,21,.12);--accent:#0f5c47;--earth:#b87936;
  --shadow:0 8px 24px rgba(42,32,18,.065);--bar:rgba(255,253,247,.88);
  --grain:rgba(30,26,21,.032);--map-filter:saturate(.92) brightness(1.02);
}
html[data-theme="night"]{
  --bg:#0b1110;--surface:#141b18;--surface-2:#202822;
  --ink:#f2eadf;--text:#ede5db;--muted:#b5aa9d;--soft:#7d756b;
  --line:rgba(242,234,223,.12);--accent:#72d6b2;--earth:#d39a55;
  --shadow:0 12px 32px rgba(0,0,0,.42);--bar:rgba(20,27,24,.84);
  --grain:rgba(245,245,247,.025);--map-filter:saturate(.7) brightness(.72) contrast(1.06);
}

*{box-sizing:border-box}
html,body{touch-action:manipulation;-webkit-text-size-adjust:100%;overscroll-behavior:none}
html{height:100%;background:var(--bg);scroll-behavior:smooth}
body{margin:0;min-height:100%;background:var(--bg);color:var(--ink);font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}

/* Texture grana */
body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background:linear-gradient(var(--grain) 1px,transparent 1px),linear-gradient(90deg,var(--grain) 1px,transparent 1px);background-size:22px 22px;mask-image:linear-gradient(to bottom,black,transparent 80%);-webkit-mask-image:linear-gradient(to bottom,black,transparent 80%)}
/* Top accent strip */
body:after{display:none}

button,a,textarea,input{font:inherit;color:inherit}
button{border:0;background:none;padding:0;cursor:pointer;-webkit-tap-highlight-color:transparent}
a{text-decoration:none}
h1,h2,h3,p{margin:0}

.app{position:relative;width:var(--app);min-height:100dvh;margin:0 auto;padding:calc(16px + var(--safe-top)) calc(18px + var(--safe-right)) calc(94px + var(--safe-bottom)) calc(18px + var(--safe-left));z-index:1}

/* TOPBAR */
.topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:16px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.12em;font-weight:820}
.eyebrow:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent)}
.topbar h1{margin-top:4px;font-size:34px;line-height:.98;letter-spacing:-.055em;font-weight:830}
.top-actions{display:flex;gap:8px;align-items:center;padding-bottom:4px}

/* BUTTONS */
.btn{min-height:var(--tap);display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 16px;border-radius:999px;font-size:14px;line-height:1;font-weight:760;white-space:nowrap;position:relative;overflow:hidden;transition:transform .16s var(--ease),opacity .12s var(--ease),background-color .26s var(--ease),border-color .26s var(--ease),color .26s var(--ease),box-shadow .26s var(--ease)}
.btn:active{opacity:.9;transform:scale(.965)}
.btn:focus-visible{outline:0;box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 18%,transparent)}
.btn.primary{background:var(--accent);color:var(--surface);border:none}
.btn.secondary{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.compact{min-height:38px;padding:0 13px;font-size:12px}
.btn.icon{width:40px;padding:0;position:relative;overflow:hidden}
.btn.small{min-height:36px;font-size:13px;padding:0 12px}
.btn.ghost{background:var(--surface-2);border:none;color:var(--text)}
.btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.btn[aria-disabled="true"]{opacity:.45;pointer-events:none;cursor:not-allowed}

/* Icone tema sole/luna */
.theme-icon-sun,.theme-icon-moon{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:opacity .22s var(--ease),transform .34s var(--ease)}
.theme-icon-moon{opacity:0}
html[data-theme="night"] .theme-icon-sun{opacity:0}
html[data-theme="night"] .theme-icon-moon{opacity:1}

.topbar h1{cursor:default;-webkit-user-select:none;user-select:none}

.view{display:none;animation:enter .18s var(--ease) both}
.view.active{display:block}
@keyframes enter{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* STAGE CARD */
.stage{position:relative;overflow:hidden;border-radius:30px;background:var(--surface);box-shadow:var(--shadow);border:1px solid var(--line)}
/* Fascia superiore pulita: niente curva che “mangia” il verde */
.stage-art{height:108px;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--earth) 58%,var(--accent)));background-size:cover;background-position:center;isolation:isolate}
.stage-art:before{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,rgba(0,0,0,.10),rgba(0,0,0,.24)),radial-gradient(circle at 82% 22%,rgba(255,255,255,.24),transparent 25%),radial-gradient(circle at 18% 84%,rgba(255,255,255,.12),transparent 30%);opacity:.95}
.stage-art:after{content:"";position:absolute;right:22px;bottom:0;z-index:1;width:118px;height:74px;background:rgba(0,0,0,.16);clip-path:polygon(0 100%,46% 18%,60% 35%,72% 12%,100% 100%)}
.stage-art.has-image:after{opacity:0}
html[data-theme="night"] .stage-art{background:linear-gradient(135deg,#0b2019,#1b3d2e 58%,#4b351c)}
html[data-theme="night"] .stage-art:before{background:radial-gradient(circle at 82% 22%,rgba(255,255,255,.13),transparent 25%),radial-gradient(circle at 18% 84%,rgba(255,255,255,.08),transparent 30%)}

/* Frecce navigazione tappe */
.stage-nav{position:absolute;top:0;bottom:0;display:flex;align-items:center;padding:0 8px;z-index:4}
.stage-nav.prev{left:0}.stage-nav.next{right:0}
.stage-nav-btn{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.25);transition:background .14s var(--ease),transform .16s var(--ease),opacity .16s var(--ease)}
.stage-nav-btn:active{background:rgba(255,255,255,.32);transform:scale(.92)}
.stage-nav-btn svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.stage-nav-btn[disabled]{opacity:.3;pointer-events:none}

.stage-content{padding:18px 18px 18px}
.stage-kicker{font-size:12px;line-height:1.2;color:var(--accent);font-weight:820;letter-spacing:.02em;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.stage-kicker:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--earth);flex-shrink:0}
.stage h2{font-size:36px;line-height:.96;letter-spacing:-.065em;font-weight:850;max-width:11ch}
.summary{margin-top:10px;color:var(--muted);font-size:15px;line-height:1.43;max-width:35ch}
.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}


.data{margin-top:16px;background:color-mix(in srgb,var(--surface-2) 72%,var(--surface));border-radius:20px;padding:2px 14px}
.data-row{display:grid;grid-template-columns:100px 1fr;gap:10px;padding:13px 0;border-top:1px solid var(--line);align-items:baseline}
.data-row:first-child{border-top:0}
.data-row span,.label{font-size:12px;line-height:1.25;color:var(--muted);font-weight:700}
.data-row b{font-size:15px;line-height:1.25;color:var(--text);font-weight:730}

.block{margin-top:18px}
.block h3,.section h2,.section h3{font-size:21px;line-height:1.08;letter-spacing:-.035em;font-weight:820;margin-bottom:12px}
.plan{display:grid}
.step{display:grid;grid-template-columns:96px 1fr;gap:10px;padding:12px 0;border-top:1px solid var(--line);align-items:baseline}
.step:first-child{border-top:0}
.step span{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--earth);font-weight:840;line-height:1.4;min-width:0;overflow-wrap:break-word}
.step p{font-size:15px;line-height:1.4;color:var(--text)}
.plan-section{margin:8px 0;padding:12px;border:1px solid color-mix(in srgb,var(--line) 78%,transparent);border-radius:18px;background:color-mix(in srgb,var(--surface-2) 54%,transparent)}
.plan-section h4{margin:0 0 8px;font-size:12px;text-transform:uppercase;letter-spacing:.055em;color:var(--earth);font-weight:880;line-height:1.2}
.plan-section p{margin:6px 0 0;color:var(--ink);font-size:15px;line-height:1.4}
.plan-section p:first-of-type{margin-top:0}


.note{width:100%;min-height:108px;margin-top:9px;padding:14px;border:1px solid var(--line);outline:none;border-radius:18px;background:color-mix(in srgb,var(--surface-2) 60%,var(--surface));color:var(--ink);resize:vertical;font-size:16px;line-height:1.42;transition:border-color .14s,box-shadow .14s}
.note:focus{border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 14%,transparent)}

.section{margin-top:22px}.section.plain{padding:0 2px}
.section-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px}
.section-row p,.section-copy{margin-top:4px;color:var(--muted);font-size:14px;line-height:1.35}

.next-list{display:grid}
.list-row{display:grid;grid-template-columns:62px 1fr;gap:12px;padding:14px 0;border-top:1px solid var(--line);align-items:baseline}
.list-row span{font-size:12px;color:var(--accent);font-weight:860;letter-spacing:.04em;line-height:1.2}
.list-row b{display:block;font-size:16px;line-height:1.2;font-weight:780}
.list-row p{margin-top:3px;color:var(--muted);font-size:14px;line-height:1.28}

/* ITINERARIO */
.days-list{display:grid;gap:10px}
details.day{background:var(--surface);border:1px solid var(--line);border-radius:24px;overflow:hidden;transition:border-color .24s var(--ease),box-shadow .24s var(--ease),background-color .24s var(--ease),transform .18s var(--ease)}
details[open].day{border-color:color-mix(in srgb,var(--accent) 24%,var(--line));box-shadow:0 8px 22px rgba(42,32,18,.045)}
html[data-theme="night"] details[open].day{box-shadow:0 10px 26px rgba(0,0,0,.24)}
details.day summary{list-style:none;min-height:74px;display:grid;grid-template-columns:58px 1fr 22px;gap:12px;align-items:center;padding:12px;cursor:pointer;transition:background-color .22s var(--ease),transform .16s var(--ease)}
details.day summary::-webkit-details-marker{display:none}
.date-chip{height:50px;border-radius:14px;background:var(--surface-2);display:grid;place-items:center;text-align:center;font-size:12px;font-weight:840;color:var(--accent);line-height:1.2}
details.day b{display:block;font-size:16px;line-height:1.18;letter-spacing:-.02em}
details.day small{display:block;margin-top:4px;color:var(--muted);font-size:13px;line-height:1.28}
.chevron svg{width:16px;height:16px;stroke:var(--soft);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .16s var(--ease)}
details[open] .chevron svg{transform:rotate(180deg)}
.day-body{padding:0 14px 16px 14px}
.day-copy{font-size:14px;line-height:1.44;color:var(--muted);margin-bottom:12px}
.day-actions{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
#view-days .day-body .plan{margin-top:2px}
#view-days .day-body .step{grid-template-columns:96px 1fr}
#view-days .day-copy{max-width:none}
#view-days .note{min-height:116px}

.day-empty{border:1px solid var(--line);border-radius:24px;background:var(--surface);padding:18px;color:var(--text)}
.day-empty b{display:block;font-size:17px;line-height:1.2}
.day-empty p{margin-top:5px;color:var(--muted);font-size:14px;line-height:1.38}

/* MAPPA */
#view-map{margin-top:0}
#view-map .section{margin-top:0;min-height:calc(100dvh - 146px - var(--safe-top) - var(--safe-bottom));display:flex;flex-direction:column}
.map-header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-bottom:8px;flex-shrink:0}
.map-header h2{font-size:21px;line-height:1.08;letter-spacing:-.035em;font-weight:820;margin:0}
.map-hint{margin:-2px 0 12px;color:var(--muted);font-size:13px;line-height:1.35;flex-shrink:0}
.map-card{position:relative;overflow:hidden;border-radius:30px;border:1px solid var(--line);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 6%,var(--surface-2)),var(--surface-2));box-shadow:0 10px 26px rgba(42,32,18,.065);height:min(44dvh,430px);min-height:300px;flex:0 0 auto;isolation:isolate}
html[data-theme="night"] .map-card{box-shadow:0 12px 30px rgba(0,0,0,.26);background:linear-gradient(180deg,#17221c,#111814)}
#map{position:absolute;inset:0;width:100%;height:100%;background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 8%,var(--surface-2)),var(--surface-2));overflow:hidden;touch-action:manipulation}
.route-map{position:absolute;inset:0;padding:14px}.route-map svg{display:block;width:100%;height:100%}.route-land{fill:color-mix(in srgb,var(--sand) 45%,var(--surface));stroke:color-mix(in srgb,var(--line) 70%,transparent);stroke-width:1.2}.route-water{fill:color-mix(in srgb,var(--accent) 10%,#dce9df);opacity:.42}.route-grid{stroke:color-mix(in srgb,var(--line) 46%,transparent);stroke-width:1}.route-line{fill:none;stroke:var(--accent);stroke-width:8;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 4px 5px rgba(0,0,0,.12))}.route-progress{fill:none;stroke:var(--earth);stroke-width:9;stroke-linecap:round;stroke-linejoin:round}.route-pin{cursor:pointer}.route-pin circle{fill:var(--surface);stroke:var(--accent);stroke-width:5;filter:drop-shadow(0 6px 10px rgba(0,0,0,.18))}.route-pin text{fill:var(--accent);font-size:17px;font-weight:900;text-anchor:middle;dominant-baseline:middle}.route-pin.current circle{fill:var(--earth);stroke:#fff}.route-pin.current text{fill:#fff}.route-pin.selected circle{fill:var(--ink);stroke:var(--earth);stroke-width:6}.route-pin.selected text{fill:#fff}.route-label rect{fill:color-mix(in srgb,var(--surface) 92%,transparent);stroke:color-mix(in srgb,var(--line) 74%,transparent);stroke-width:1}.route-label text{fill:var(--ink);font-size:13px;font-weight:800}.route-label .muted{fill:var(--muted);font-size:10px;font-weight:650}.route-label.selected rect{stroke:var(--earth);stroke-width:2}.map-actions-panel{margin-top:12px;border:1px solid var(--line);border-radius:26px;background:color-mix(in srgb,var(--surface) 94%,transparent);box-shadow:0 12px 30px rgba(42,32,18,.08);padding:12px;flex-shrink:0}.map-actions-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.map-actions-top small{display:block;color:var(--accent);font-size:10px;font-weight:860;letter-spacing:.055em;text-transform:uppercase}.map-actions-top b{display:block;margin-top:2px;font-size:18px;line-height:1.12;letter-spacing:-.025em}.map-actions-top p{margin:3px 0 0;color:var(--muted);font-size:12px;line-height:1.25}.map-step-nav{display:flex;gap:6px;flex-shrink:0}.map-step-nav .btn{width:42px;padding:0;justify-content:center}.map-bottom-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.map-bottom-actions .btn{flex:1;justify-content:center;min-width:116px}.map-mini{display:flex;gap:7px;overflow-x:auto;margin-top:10px;padding-bottom:2px;scrollbar-width:none}.map-mini::-webkit-scrollbar{display:none}.map-mini button{flex:0 0 auto;min-width:38px;height:38px;border-radius:999px;border:1px solid color-mix(in srgb,var(--line) 78%,transparent);background:color-mix(in srgb,var(--surface) 90%,transparent);color:var(--muted);font-size:12px;font-weight:860;box-shadow:0 8px 18px rgba(42,32,18,.08)}.map-mini button.current{background:var(--earth);color:#fff;border-color:transparent}.map-mini button.selected{background:var(--ink);color:#fff;border-color:transparent}.map-empty{position:absolute;inset:0;display:grid;place-content:center;text-align:center;padding:22px}.map-empty b{font-size:17px}.map-empty p{margin-top:6px;color:var(--muted);font-size:14px;line-height:1.35}

.global{min-height:260px}

/* BOTTOM NAV */
.bottom{position:fixed;left:50%;bottom:0;transform:translateX(-50%);width:var(--app);z-index:20;padding:8px calc(14px + var(--safe-right)) calc(8px + var(--safe-bottom)) calc(14px + var(--safe-left));background:linear-gradient(180deg,transparent,var(--bg) 28%,var(--bg))}
.tabs{height:62px;display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:26px;background:var(--bar);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 12px 32px rgba(0,0,0,.11);overflow:hidden;position:relative}
.tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--soft);font-size:11px;font-weight:760;position:relative;transition:color .18s var(--ease),transform .16s var(--ease),background-color .22s var(--ease)}
.tab svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:transform .22s var(--ease),stroke-width .22s var(--ease)}
.tab:active{transform:scale(.96)}
.tab.active{color:var(--accent)}
.tab.active svg{transform:translateY(-2px) scale(1.06);stroke-width:1.9}
.tab.active:after{display:none}



/* TOAST */
.toast{position:fixed;left:50%;bottom:calc(82px + var(--safe-bottom));transform:translateX(-50%) translateY(8px);opacity:0;pointer-events:none;z-index:40;padding:10px 15px;border-radius:999px;background:var(--ink);color:var(--surface);font-size:13px;font-weight:750;transition:.18s var(--ease)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}


/* MOTION PACK v13.22 */
.view.active.view-forward{animation:viewInForward .28s var(--ease) both}
.view.active.view-back{animation:viewInBack .28s var(--ease) both}
@keyframes viewInForward{from{opacity:0;transform:translateX(14px) translateY(4px)}to{opacity:1;transform:none}}
@keyframes viewInBack{from{opacity:0;transform:translateX(-14px) translateY(4px)}to{opacity:1;transform:none}}

.stage.stage-forward,.stage.stage-back{animation:stageFadeIn .30s var(--ease) both}
.stage.stage-forward .stage-content,.stage.stage-back .stage-content{animation:stageContentFadeIn .32s var(--ease) both}
.stage.stage-forward .stage-art,.stage.stage-back .stage-art{animation:stageArtFadeIn .36s var(--ease) both}
@keyframes stageFadeIn{from{opacity:0}to{opacity:1}}
@keyframes stageContentFadeIn{from{opacity:0}to{opacity:1}}
@keyframes stageArtFadeIn{from{opacity:.25}to{opacity:1}}

details.day[open] summary{background:color-mix(in srgb,var(--accent) 5%,transparent)}
details.day summary:active{transform:scale(.992)}
details.day[open] .day-body{animation:accordionBodyIn .26s var(--ease) both}
@keyframes accordionBodyIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

.skeleton{display:block;position:relative;overflow:hidden;border-radius:999px;background:color-mix(in srgb,var(--surface-2) 78%,var(--surface));isolation:isolate}
.skeleton:after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--surface) 74%,transparent),transparent);animation:skeletonSweep 1.18s var(--ease) infinite}
.skeleton.sk-kicker{width:132px;height:14px;margin-bottom:12px}
.skeleton.sk-title{width:min(78%,270px);height:42px;margin:0 0 12px;border-radius:16px}
.skeleton.sk-summary{width:100%;height:15px;margin-top:8px}
.skeleton.sk-summary.short{width:72%}
.skeleton.sk-button{height:48px;border-radius:999px}
.skeleton.sk-row{height:18px;margin:13px 0;border-radius:10px}
.skeleton.sk-plan{height:72px;margin-top:10px;border-radius:18px}
@keyframes skeletonSweep{to{transform:translateX(100%)}}

html.theme-switching body,
html.theme-switching .stage,
html.theme-switching .section,
html.theme-switching details.day,
html.theme-switching .map-card,
html.theme-switching #map,
html.theme-switching .tabs,
html.theme-switching .toast,
html.theme-switching .data,
html.theme-switching .note,
html.theme-switching .plan-section,
html.theme-switching .map-actions-panel,
html.theme-switching .bottom{transition:background-color .36s var(--ease),background .36s var(--ease),color .36s var(--ease),border-color .36s var(--ease),box-shadow .36s var(--ease),filter .36s var(--ease)}
#themeBtn.theme-spinning .theme-icon-sun{transform:translate(-50%,-50%) rotate(90deg) scale(.86)}
#themeBtn.theme-spinning .theme-icon-moon{transform:translate(-50%,-50%) rotate(-90deg) scale(.86)}


@media(min-width:768px){
  :root{--app:min(100vw,640px)}
  .app{padding:calc(22px + var(--safe-top)) calc(28px + var(--safe-right)) calc(106px + var(--safe-bottom)) calc(28px + var(--safe-left))}
  .topbar{margin-bottom:20px}
  .topbar h1{font-size:42px}
  .stage{border-radius:34px}
  .stage-art{height:132px}
  .stage-content{padding:24px}
  .stage h2{font-size:44px;max-width:13ch}
  .summary{font-size:16px;max-width:48ch}
  .data-row{grid-template-columns:132px 1fr}
  .step{grid-template-columns:118px 1fr}
  #view-days .day-body .step{grid-template-columns:118px 1fr}
  #view-map .section{min-height:calc(100dvh - 150px - var(--safe-top) - var(--safe-bottom))}
  .map-card{height:min(46dvh,500px);min-height:360px;border-radius:34px}
  .map-actions-panel{border-radius:28px;padding:14px}
  .map-bottom-actions .btn{flex:0 0 auto}
  .bottom{padding:10px calc(24px + var(--safe-right)) calc(12px + var(--safe-bottom)) calc(24px + var(--safe-left))}
  .tabs{height:68px;border-radius:30px}
  .tab{font-size:12px}
}
@media(min-width:1024px) and (orientation:landscape){
  :root{--app:min(100vw,720px)}
  .stage-art{height:140px}
  #view-map .section{min-height:calc(100dvh - 150px - var(--safe-top) - var(--safe-bottom))}
  .map-card{height:min(48dvh,520px);min-height:380px;border-radius:36px}
  .map-actions-panel{border-radius:30px;padding:14px}
  .map-bottom-actions .btn{flex:0 0 auto}
}

@media(max-width:370px){.app{padding-left:14px;padding-right:14px}.quick-actions{grid-template-columns:1fr}.stage h2{font-size:33px}.data-row{grid-template-columns:1fr;gap:3px}.step{grid-template-columns:1fr;gap:3px}.step span{line-height:1.2}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
@media print{.bottom,.top-actions,.toast,.stage-nav{display:none!important}.app{width:100%;padding:0}.view{display:block!important}.stage,.map-card,details.day,.stops-list{box-shadow:none;break-inside:avoid}}




/* v13.20 — mappa vettoriale Costa Rica: niente tile, niente Leaflet, base SVG georeferenziata */
.map-card{height:min(44dvh,430px);min-height:300px;background:linear-gradient(180deg,#dfe9e5,#edf1eb)}
html[data-theme="night"] .map-card{background:linear-gradient(180deg,#1d2a25,#121b17)}
#map{background:transparent;overflow:hidden;touch-action:manipulation}
.route-map{position:absolute;inset:0;padding:0;display:grid;place-items:center;background:linear-gradient(180deg,#dfe9e5,#edf1eb)}
.route-map svg{display:block;width:100%;height:100%;max-height:none}
.cr-sea{fill:#dfe9e5}
html[data-theme="night"] .cr-sea{fill:#15231f}
.cr-land path{fill:#eee6d8;stroke:#b8aa97;stroke-width:1.45;stroke-linejoin:round;vector-effect:non-scaling-stroke}
html[data-theme="night"] .cr-land path{fill:#27352f;stroke:#51645b}
.route-line{fill:none;stroke:var(--accent);stroke-width:6.5;stroke-linecap:round;stroke-linejoin:round;opacity:.88;filter:drop-shadow(0 3px 4px rgba(0,0,0,.18))}
.route-progress{fill:none;stroke:var(--earth);stroke-width:7.8;stroke-linecap:round;stroke-linejoin:round;opacity:.96}
.route-pin{cursor:pointer}.route-pin circle{fill:var(--surface);stroke:var(--accent);stroke-width:4.2;filter:drop-shadow(0 5px 8px rgba(0,0,0,.20))}.route-pin text{fill:var(--accent);font-size:12px;font-weight:900;text-anchor:middle;dominant-baseline:middle;pointer-events:none}.route-pin.current circle{fill:var(--earth);stroke:#fff}.route-pin.current text{fill:#fff}.route-pin.selected circle{fill:var(--ink);stroke:var(--earth);stroke-width:5}.route-pin.selected text{fill:#fff}
.route-pin[data-close="true"] circle{stroke-width:3.8}
.route-selected-label rect{fill:color-mix(in srgb,var(--surface) 95%,transparent);stroke:var(--earth);stroke-width:1.5;filter:drop-shadow(0 8px 16px rgba(0,0,0,.16))}.route-selected-label text{fill:var(--ink);font-weight:850;font-size:15px}.route-selected-label .muted{fill:var(--muted);font-weight:700;font-size:11px}
@media (min-width:768px){.map-card{height:min(46dvh,500px);min-height:360px}.route-line{stroke-width:5.7}.route-progress{stroke-width:6.6}.route-pin circle{r:10}}
