:root{
    /* Atlante brand v2 — tema scuro su Deep Navy */
    --ink:#07172A; --ink-2:#0E2236; --ink-3:#16314A;
    --bone:#F8FAFC; --bone-dim:#9FB2C4; --bone-faint:#5E7488;
    --navy:#0A1E3F; --teal:#00B8A9; --sky:#77CFFF; --orange:#FFB23F;
    --accent:#FFB23F; --accent-soft:rgba(255,178,63,.16);
    --line:rgba(248,250,252,.10); --line-2:rgba(248,250,252,.18);
    --surface:rgba(22,24,31,.9); --scrim:7,23,42;
    --gps:#77CFFF; --r:16px; --sheet-max:62vh; font-size:16px;
  }
  html[data-theme="light"]{
    /* tema chiaro brand — off-white + navy */
    --ink:#F8FAFC; --ink-2:#FFFFFF; --ink-3:#EDF2F8;
    --bone:#0A1E3F; --bone-dim:#5B7187; --bone-faint:#90A4B8;
    --line:rgba(10,30,63,.12); --line-2:rgba(10,30,63,.20);
    --surface:rgba(255,255,255,.94); --scrim:248,250,252;
    --gps:#2563EB;
  }
  *{box-sizing:border-box; -webkit-tap-highlight-color:transparent;}
  html,body{margin:0; height:100%; background:var(--ink); color:var(--bone);
    font-family:'Inter',system-ui,sans-serif; overscroll-behavior:none;}
  body{overflow:hidden;}
  body::after{content:""; position:fixed; inset:0; pointer-events:none; z-index:50; opacity:.05; mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

  .screen{position:fixed; inset:0; display:none; flex-direction:column;}
  .screen.on{display:flex;}
  #screen-map.on{display:block;}

  /* ===== LIBRARY ===== */
  .lib-head{padding:calc(env(safe-area-inset-top) + 22px) 20px 14px; flex:0 0 auto;}
  .lib-head .brand{display:flex; align-items:center; gap:11px;}
  .lib-head .logo-mark{flex:0 0 auto; width:32px; height:32px; display:block;}
  .sym-light{display:none;}
  html[data-theme="light"] .sym-dark{display:none;}
  html[data-theme="light"] .sym-light{display:block;}
  .lib-head h1{font-family:'Poppins',sans-serif; font-weight:600; font-size:1.9rem; margin:0; line-height:1; letter-spacing:.005em; color:var(--bone);}
  .lib-head .dot{width:7px; height:7px; border-radius:50%; background:var(--accent); transform:translateY(-5px);}
  .lib-head .tag{color:var(--bone-dim); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; margin-top:6px;}
  .lib-body{flex:1; overflow-y:auto; padding:6px 16px 120px;}
  .map-card{display:block; width:100%; text-align:left; background:var(--ink-2); border:1px solid var(--line);
    border-radius:var(--r); padding:16px 18px; margin-bottom:12px; cursor:pointer; transition:.15s; color:inherit; position:relative;}
  .map-card:active{transform:scale(.99);}
  .map-card h2{font-family:'Poppins',sans-serif; font-weight:500; font-size:1.3rem; margin:0;}
  .map-card .meta{color:var(--bone-dim); font-size:.82rem; margin-top:3px;}
  .map-card .dots{display:flex; gap:5px; margin-top:12px; flex-wrap:wrap;}
  .map-card .ld{display:inline-flex; align-items:center; gap:5px; font-size:.72rem; color:var(--bone-dim);
    background:var(--ink-3); border-radius:999px; padding:4px 9px;}
  .map-card .ld i{width:7px; height:7px; border-radius:50%; font-style:normal;}
  .map-card .del{position:absolute; top:14px; right:14px; width:30px; height:30px; border-radius:50%;
    border:1px solid var(--line); background:transparent; color:var(--bone-faint); cursor:pointer; font-size:.9rem;}
  .lib-empty{color:var(--bone-dim); text-align:center; padding:60px 20px; line-height:1.6;}

  .fab-new{position:fixed; left:16px; right:16px; bottom:calc(env(safe-area-inset-bottom) + 18px); z-index:20;
    padding:16px; border-radius:var(--r); border:none; background:var(--accent); color:var(--ink);
    font-family:'Inter'; font-weight:700; font-size:1rem; cursor:pointer; box-shadow:0 8px 24px rgba(255,178,63,.32);}
  .lib-tools{position:absolute; top:calc(env(safe-area-inset-top) + 24px); right:18px; display:flex; gap:8px;}
  .icon-btn{width:40px; height:40px; border-radius:50%; border:1px solid var(--line); background:var(--ink-2);
    color:var(--bone-dim); display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:1.05rem;}

  /* ===== NEW MAP ===== */
  .new-head{display:flex; align-items:center; gap:12px; padding:calc(env(safe-area-inset-top) + 18px) 18px 12px; flex:0 0 auto;}
  .new-head h1{font-family:'Poppins',sans-serif; font-weight:500; font-size:1.5rem; margin:0; flex:1;}
  .new-body{flex:1; overflow-y:auto; padding:6px 18px 30px;}
  .field{margin-bottom:18px;}
  .field label{display:block; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--bone-faint); margin-bottom:7px;}
  .field input, .field select, .field textarea{width:100%; padding:13px 14px; border-radius:12px; background:var(--ink-2);
    border:1px solid var(--line-2); color:var(--bone); font-family:'Inter'; font-size:1rem; outline:none;}
  .field input:focus, .field select:focus, .field textarea:focus{border-color:var(--accent);}
  .field textarea{resize:vertical; min-height:48px; line-height:1.45;}
  .field label .opt{text-transform:none; letter-spacing:0; color:var(--bone-faint); font-weight:400;}
  .field .pair{display:flex; gap:10px;}
  .combo{position:relative;}
  .suggest{position:absolute; left:0; right:0; top:calc(100% + 6px); z-index:30;
    background:var(--ink-2); border:1px solid var(--line-2); border-radius:12px;
    max-height:260px; overflow-y:auto; display:none; box-shadow:0 12px 30px rgba(0,0,0,.35);}
  .suggest.show{display:block;}
  .suggest .si{display:flex; align-items:center; gap:11px; padding:11px 13px; cursor:pointer; border-bottom:1px solid var(--line);}
  .suggest .si:last-child{border-bottom:none;}
  .suggest .si:hover, .suggest .si.act{background:var(--ink-3);}
  .suggest .si .flag{font-size:1.25rem; flex:0 0 auto; line-height:1;}
  .suggest .si .txt{min-width:0;}
  .suggest .si .nm{font-size:.95rem; color:var(--bone); white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
  .suggest .si .sub{font-size:.75rem; color:var(--bone-dim); white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
  .suggest .si.muted{color:var(--bone-dim); cursor:default; justify-content:center; font-size:.82rem;}
  .lay-grid{display:grid; grid-template-columns:1fr 1fr; gap:9px;}
  .lay{display:flex; align-items:center; gap:9px; padding:12px; border-radius:12px; background:var(--ink-2);
    border:1px solid var(--line); cursor:pointer; font-size:.9rem; font-weight:600; transition:.14s;}
  .lay .sw{width:11px; height:11px; border-radius:50%; flex:0 0 auto;}
  .lay.sel{border-color:var(--accent); background:var(--accent-soft);}
  .lay .chk{margin-left:auto; color:var(--accent); opacity:0; font-size:.9rem;}
  .lay.sel .chk{opacity:1;}
  .gen-btn{width:100%; padding:16px; border-radius:var(--r); border:none; background:var(--accent); color:var(--navy);
    font-family:'Inter'; font-weight:700; font-size:1rem; cursor:pointer; margin-top:8px;}
  .gen-btn:disabled{opacity:.5; cursor:default;}
  .progress{margin:18px 18px 0; display:none;}
  .progress.on{display:block;}
  .progress .bar{height:4px; border-radius:4px; background:var(--ink-3); overflow:hidden;}
  .progress .bar i{display:block; height:100%; background:var(--accent); width:0; transition:width .3s; font-style:normal;}
  .progress .msg{font-size:.85rem; color:var(--bone-dim); margin-top:9px;}
  .progress .msg.err{color:var(--orange);}
  .step-body{flex:1; overflow-y:auto; padding:6px 18px 12px;}
  .step-prog{display:flex; gap:6px; margin:8px 0 24px;}
  .step-prog i{height:4px; border-radius:2px; flex:1; background:var(--line-2); transition:background .2s;}
  .step-prog i.on{background:var(--accent);}
  .step-q{font-family:'Poppins',sans-serif; font-weight:600; font-size:1.35rem; line-height:1.25; margin-bottom:20px; color:var(--bone);}
  .step-opts{display:flex; flex-direction:column; gap:10px;}
  .opt-chip{display:flex; align-items:center; gap:13px; padding:15px 16px; border-radius:14px;
    background:var(--ink-2); border:1px solid var(--line-2); cursor:pointer; color:var(--bone); font-size:.98rem;}
  .opt-chip .em{font-size:1.3rem; flex:0 0 auto; line-height:1;}
  .opt-chip .tick{margin-left:auto; color:var(--accent); font-weight:700; opacity:0;}
  .opt-chip.sel{border-color:var(--accent); background:var(--accent-soft);}
  .opt-chip.sel .tick{opacity:1;}
  .step-nav{flex:0 0 auto; display:flex; gap:10px; padding:12px 18px calc(env(safe-area-inset-bottom) + 16px);}
  .step-nav .gen-btn{flex:1; margin-top:0;}
  .btn-ghost{flex:0 0 auto; padding:16px 18px; border-radius:var(--r); background:transparent;
    border:1px solid var(--line-2); color:var(--bone-dim); font-family:'Inter'; font-weight:600; cursor:pointer;}

  /* ===== MAP (field app) ===== */
  #map{position:absolute; inset:0;}
  .top{position:absolute; top:0; left:0; right:0; z-index:10; padding:calc(env(safe-area-inset-top) + 12px) 16px 8px;
    background:linear-gradient(180deg, rgba(var(--scrim),.92), rgba(var(--scrim),.78) 55%, rgba(var(--scrim),0)); pointer-events:none;}
  .top > *{pointer-events:auto;}
  .top .row1{display:flex; align-items:center; gap:12px;}
  .back-map{width:36px; height:36px; border-radius:50%; border:1px solid var(--line-2); background:var(--surface);
    color:var(--bone); display:flex; align-items:center; justify-content:center; font-size:1.2rem; cursor:pointer; backdrop-filter:blur(8px);}
  .top h1{font-family:'Poppins',sans-serif; font-weight:500; font-size:1.3rem; margin:0; line-height:1;}
  .top .sub{font-size:.72rem; color:var(--bone-dim); letter-spacing:.16em; text-transform:uppercase; margin-top:2px;}
  .month-sel{flex:0 0 auto; background:var(--surface); color:var(--bone); border:1px solid var(--line-2);
    border-radius:999px; padding:8px 12px; font-family:'Inter'; font-size:.82rem; font-weight:600; backdrop-filter:blur(8px); outline:none; cursor:pointer; max-width:42vw;}
  .pin.off-season{opacity:.32; filter:grayscale(.7);}
  .season-tag{display:inline-flex; align-items:center; gap:5px; font-size:.74rem; font-weight:600; padding:5px 10px; border-radius:8px; margin-top:8px;}
  .season-tag.in{background:rgba(111,168,108,.15); color:#8fce8b; border:1px solid rgba(111,168,108,.3);}
  .season-tag.out{background:rgba(168,168,168,.12); color:var(--bone-dim); border:1px solid var(--line-2);}
  .row.off-season{opacity:.5;}
  .chips{position:absolute; top:calc(env(safe-area-inset-top) + 64px); left:0; right:0; z-index:10;
    display:flex; gap:8px; padding:6px 16px 10px; overflow-x:auto; scrollbar-width:none;}
  .chips::-webkit-scrollbar{display:none;}
  .chip{flex:0 0 auto; display:inline-flex; align-items:center; gap:7px; padding:8px 13px; border-radius:999px;
    background:var(--surface); border:1px solid var(--line); color:var(--bone-dim);
    font-size:.82rem; font-weight:600; white-space:nowrap; backdrop-filter:blur(8px); cursor:pointer;}
  .chip.on{color:var(--ink); border-color:transparent;}
  .chip.off{opacity:.5;}

  .pin-wrap{width:30px; height:30px; cursor:pointer;}
  .pin{width:30px; height:30px; border-radius:50% 50% 50% 2px; transform:rotate(45deg);
    border:2px solid rgba(var(--scrim),.55); box-shadow:0 4px 10px rgba(0,0,0,.45); cursor:pointer; position:relative;}
  .pin > span{display:flex; align-items:center; justify-content:center; width:100%; height:100%; transform:rotate(-45deg); font-size:14px;}
  .pin.must::after{content:"\2605"; position:absolute; top:-9px; right:-9px; transform:rotate(-45deg);
    color:#fff; background:var(--accent); width:16px; height:16px; border-radius:50%; font-size:9px;
    display:flex; align-items:center; justify-content:center;}
  .pin.sel{transform:rotate(45deg) scale(1.25); z-index:3;}
  .gps-wrap{position:relative; width:0; height:0;}
  .gps-wrap .gps-dot{position:absolute; left:-9px; top:-9px;}
  .gps-beam{position:absolute; left:-26px; top:-50px; width:52px; height:50px;
    background:linear-gradient(to top, rgba(119,207,255,.55), rgba(119,207,255,0) 78%);
    clip-path:polygon(50% 100%, 8% 0, 92% 0); transform-origin:50% 100%; pointer-events:none; display:none;}
  .gps-dot{width:18px; height:18px; border-radius:50%; background:var(--gps); border:3px solid #fff; box-shadow:0 0 0 2px rgba(91,168,255,.4); position:relative;}
  .gps-dot::before{content:""; position:absolute; inset:-9px; border-radius:50%; background:rgba(91,168,255,.25); animation:pulse 2.2s ease-out infinite;}
  @keyframes pulse{0%{transform:scale(.6); opacity:.7} 100%{transform:scale(2.2); opacity:0}}

  .fabs{position:absolute; right:16px; bottom:calc(env(safe-area-inset-bottom) + 22px); z-index:12; display:flex; flex-direction:column; gap:12px;}
  .fab{width:52px; height:52px; border-radius:50%; border:1px solid var(--line-2); background:var(--surface);
    color:var(--bone); display:flex; align-items:center; justify-content:center; backdrop-filter:blur(8px); box-shadow:0 6px 18px rgba(0,0,0,.4); cursor:pointer;}
  .fab svg{width:22px; height:22px; stroke:currentColor; fill:none; stroke-width:1.8;}
  .fab.near.on{background:var(--accent); color:var(--ink); border-color:transparent;}
  .fab.loading{opacity:.6;}

  .radius{position:absolute; left:16px; right:84px; bottom:calc(env(safe-area-inset-bottom) + 22px); z-index:11;
    background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:12px 16px;
    backdrop-filter:blur(10px); transform:translateY(140%); opacity:0; transition:.24s cubic-bezier(.22,1,.36,1);}
  .radius.show{transform:translateY(0); opacity:1;}
  .radius .lab{display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px;}
  .radius .lab small{color:var(--bone-dim); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;}
  .radius .lab b{font-family:'Poppins',sans-serif; font-weight:500; font-size:1.05rem;}
  input[type=range]{-webkit-appearance:none; width:100%; height:3px; border-radius:3px; background:var(--line-2); outline:none;}
  input[type=range]::-webkit-slider-thumb{-webkit-appearance:none; width:18px; height:18px; border-radius:50%; background:var(--accent); border:2px solid var(--ink);}

  .sheet{position:absolute; left:0; right:0; bottom:0; z-index:14; background:var(--ink-2);
    border-top:1px solid var(--line-2); border-radius:22px 22px 0 0; box-shadow:0 -10px 40px rgba(0,0,0,.5);
    transform:translateY(110%); transition:transform .3s cubic-bezier(.22,1,.36,1); max-height:var(--sheet-max); display:flex; flex-direction:column; padding-bottom:env(safe-area-inset-bottom);}
  .sheet.show{transform:translateY(0);}
  .handle{width:40px; height:4px; border-radius:4px; background:var(--line-2); margin:10px auto 4px; flex:0 0 auto;}
  .sheet-head{display:flex; align-items:center; gap:10px; padding:4px 18px 10px; flex:0 0 auto;}
  .sheet-head h2{font-family:'Poppins',sans-serif; font-weight:500; font-size:1.15rem; margin:0; flex:1;}
  .sheet-head .x,.sheet-head .back{width:32px; height:32px; border-radius:50%; border:1px solid var(--line);
    background:transparent; color:var(--bone-dim); display:flex; align-items:center; justify-content:center; cursor:pointer;}
  .sheet-body{overflow-y:auto; padding:0 18px 22px;}
  .row{display:flex; gap:13px; align-items:flex-start; padding:13px 0; border-bottom:1px solid var(--line); cursor:pointer;}
  .row:last-child{border-bottom:none;}
  .row .glyph{flex:0 0 auto; width:34px; height:34px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:15px;}
  .row .meta{flex:1; min-width:0;}
  .row .meta .nm{font-weight:600; font-size:.95rem; display:flex; align-items:center; gap:6px;}
  .row .meta .nm .star{color:var(--accent); font-size:.8rem;}
  .row .meta .cat{color:var(--bone-dim); font-size:.78rem; margin-top:1px;}
  .row .dist{flex:0 0 auto; text-align:right; color:var(--bone); font-weight:600; font-size:.82rem;}
  .row .dist small{display:block; color:var(--bone-faint); font-weight:500; font-size:.64rem; letter-spacing:.1em;}
  .d-cat{font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; font-weight:700;}
  .d-area{color:var(--bone-dim); font-size:.82rem; margin-top:2px;}
  .facts{display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:12px; overflow:hidden; margin:16px 0;}
  .fact{background:var(--ink-2); padding:11px 13px;}
  .fact small{display:block; color:var(--bone-faint); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:3px;}
  .fact b{font-weight:600; font-size:.92rem;}
  .notes{font-size:.95rem; line-height:1.55; margin:4px 0 14px;}
  .warns{display:flex; flex-wrap:wrap; gap:7px; margin-bottom:16px;}
  .warn{font-size:.74rem; font-weight:600; padding:5px 10px; border-radius:8px; background:rgba(224,133,63,.12); color:var(--accent); border:1px solid rgba(224,133,63,.25);}
  .cta{display:flex; align-items:center; justify-content:center; gap:8px; width:100%; padding:14px; border-radius:12px; background:var(--accent); color:var(--navy); font-weight:700; font-size:.92rem; text-decoration:none; border:none; cursor:pointer; margin-top:14px;}
  .cta.alt{background:transparent; color:var(--teal); border:1px solid var(--teal); margin-top:10px;}
  .cta svg{width:17px; height:17px; stroke:currentColor; fill:none; stroke-width:2;}
  .must-badge{display:inline-flex; align-items:center; gap:5px; font-size:.74rem; font-weight:700; color:var(--accent); margin-top:8px;}
  .empty{color:var(--bone-dim); text-align:center; padding:30px 10px; font-size:.9rem; line-height:1.5;}
  #file{display:none;}
  .maplibregl-ctrl-attrib{font-size:9px; background:rgba(var(--scrim),.6)!important;}
  .maplibregl-ctrl-attrib a{color:var(--bone-dim)!important;}
  .sheet-head .favbtn{width:32px; height:32px; border-radius:50%; border:1px solid var(--line);
    background:transparent; color:var(--orange); font-size:1.05rem; display:flex; align-items:center; justify-content:center; cursor:pointer;}
  .sheet-head .favbtn.on{background:rgba(255,178,63,.16); border-color:transparent;}
  .chip.fav{border:1px solid rgba(255,178,63,.4);}
  .modal{position:fixed; inset:0; z-index:60; background:rgba(7,23,42,.6); backdrop-filter:blur(4px);
    display:none; align-items:flex-end; justify-content:center;}
  .modal.show{display:flex;}
  .modal-card{width:100%; max-width:520px; background:var(--ink-2); border:1px solid var(--line-2);
    border-radius:22px 22px 0 0; padding:8px 20px calc(env(safe-area-inset-bottom) + 24px); animation:rise .26s cubic-bezier(.22,1,.36,1);}
  @keyframes rise{from{transform:translateY(30px); opacity:0} to{transform:translateY(0); opacity:1}}
  .modal-head{display:flex; align-items:center; padding:12px 0 14px;}
  .modal-head h2{font-family:'Poppins',sans-serif; font-weight:600; font-size:1.2rem; margin:0; flex:1;}
  .modal-head .x{width:32px; height:32px; border-radius:50%; border:1px solid var(--line); background:transparent; color:var(--bone-dim); cursor:pointer;}
  .modal-note{color:var(--bone-dim); font-size:.8rem; margin:10px 0 0; line-height:1.5;}
  .icon-round{flex:0 0 auto; width:38px; height:38px; border-radius:50%; border:1px solid var(--line-2);
    background:var(--surface); color:var(--bone); font-size:1.05rem; cursor:pointer; display:flex; align-items:center; justify-content:center;}
  .edit-row{display:flex; align-items:center; gap:10px; padding:11px 12px; border-radius:12px; background:var(--ink-2); border:1px solid var(--line); margin-bottom:8px;}
  .edit-row .nm{flex:1; min-width:0; color:var(--bone); font-size:.95rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
  .edit-row .sw{width:12px; height:12px; border-radius:3px; flex:0 0 auto;}
  .edit-row button{flex:0 0 auto; border:1px solid var(--line-2); background:transparent; color:var(--bone-dim);
    border-radius:9px; padding:7px 10px; font-size:.8rem; cursor:pointer; font-family:'Inter';}
  .edit-row button.danger{color:var(--orange); border-color:rgba(255,178,63,.4);}
  .sheet-del{display:block; width:100%; text-align:center; margin-top:14px; background:none; border:none;
    color:var(--bone-faint); font-size:.82rem; text-decoration:underline; cursor:pointer; font-family:'Inter';}
