:root {
  --bg: #f2f3f5;
  --white: #ffffff;
  --text: #1c1c1e;
  --text-muted: #6e6e73;
  --border: #e0e0e5;
  --red: #c8102e;
  --red-hover: #a50d25;
  --green: #1a7f3c;
  --green-bg: #e9f7ef;
  --radius-card: 14px;
  --radius: 10px;
  --shadow: 0 2px 8px rgba(0,0,0,0.09), 0 1px 2px rgba(0,0,0,0.06);
  --shadow-hover: 0 8px 28px rgba(0,0,0,0.14), 0 2px 6px rgba(0,0,0,0.08);
  --modal-shadow: 0 24px 80px rgba(0,0,0,0.25);
}

*{box-sizing:border-box;margin:0;padding:0;}

.graubuenden-logo{
  height:2.475rem;
  vertical-align:middle;
  display:inline-block;
}
.logo-text h1 .ski-text{
  vertical-align:middle;
  position:relative;
  top:0.3em;
}

body{
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  line-height:1.5;
}

/* ── HEADER ── */
header{
  background:var(--white);
  border-bottom:3px solid var(--red);
  position:sticky;top:0;z-index:200;
  box-shadow:0 2px 8px rgba(0,0,0,0.07);
}
.header-inner{
  max-width:1100px;margin:0 auto;
  padding:0 1.5rem;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;height:64px;
}
.logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;}
.logo-mark{
  background:var(--red);color:white;
  width:40px;height:40px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;flex-shrink:0;
}
.logo-text h1{font-size:1.35rem;font-weight:700;color:var(--text);line-height:1.2;}
.logo-text p{font-size:.72rem;color:var(--text-muted);line-height:1;}
.header-right{display:flex;align-items:center;gap:.75rem;}

/* Language switcher */
.lang-switcher{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;}
.lang-btn{
  background:none;border:none;border-right:1px solid var(--border);
  padding:.3rem .5rem;
  cursor:pointer;
  transition:all .15s;
  display:flex;align-items:center;justify-content:center;
  opacity:.5;
}
.lang-btn img{
  width:26px;height:18px;
  object-fit:cover;border-radius:2px;
  display:block;
}
.lang-btn:last-child{border-right:none;}
.lang-btn:hover{background:var(--bg);opacity:.85;}
.lang-btn.active{background:#f0f0f0;opacity:1;box-shadow:inset 0 0 0 2px var(--red);}

/* Resident toggle */
.resident-wrap{
  display:flex;align-items:center;gap:.5rem;
  cursor:pointer;
  padding:.35rem .85rem;
  border:1.5px solid var(--border);border-radius:8px;
  background:var(--white);
  transition:border-color .15s,background .15s;
  user-select:none;
}
.resident-wrap:hover{border-color:var(--red);}
.resident-wrap.is-active{border-color:var(--green);background:var(--green-bg);}
.resident-wrap input[type=checkbox]{display:none;}
.toggle-track{
  width:34px;height:19px;background:#ccc;
  border-radius:10px;position:relative;transition:background .15s;flex-shrink:0;
}
.toggle-thumb{
  position:absolute;top:2px;left:2px;
  width:15px;height:15px;background:white;
  border-radius:50%;transition:left .15s;
  box-shadow:0 1px 3px rgba(0,0,0,0.2);
}
input[type=checkbox]:checked~.toggle-track{background:var(--green);}
input[type=checkbox]:checked~.toggle-track .toggle-thumb{left:17px;}
.resident-label{font-size:.8rem;font-weight:600;color:var(--text-muted);white-space:nowrap;cursor:pointer;}
.resident-wrap.is-active .resident-label{color:var(--green);}

/* ── TOOLBAR ── */
.toolbar{
  max-width:1100px;margin:0 auto;
  padding:1.5rem 1.5rem .75rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.toolbar-title{font-size:1.3rem;font-weight:700;color:var(--text);}
.toolbar-sub{font-size:.82rem;color:var(--text-muted);margin-top:2px;}
.sort-select{
  background:var(--white);border:1px solid var(--border);
  color:var(--text);border-radius:8px;
  padding:.45rem .85rem;font-size:.82rem;
  cursor:pointer;outline:none;transition:border-color .15s;
}
.sort-select:hover{border-color:var(--red);}

/* ── CARD GRID ── */
main{max-width:1100px;margin:0 auto;padding:0 1.5rem 2rem;}
footer{text-align:center;padding:1.25rem 1.5rem 2rem;font-size:.78rem;color:var(--text-muted);border-top:1px solid var(--border);margin-top:1rem;}

.resort-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
}

/* ── RESORT CARD ── */
.resort-card{
  background:var(--white);
  border-radius:var(--radius-card);
  overflow:hidden;
  box-shadow:var(--shadow);
  cursor:pointer;
  transition:transform .2s,box-shadow .2s;
  border:1px solid var(--border);
  display:flex;flex-direction:column;
}
.resort-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-hover);
}
.resort-card:hover .card-name{color:var(--red);}

/* Card image */
.card-img{
  position:relative;
  height:190px;
  overflow:hidden;
  flex-shrink:0;
}
.card-img-bg{
  width:100%;height:100%;
  background-size:cover;background-position:center;
  transition:transform .35s;
}
.resort-card:hover .card-img-bg{transform:scale(1.04);}
.card-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.55) 100%);
}
.card-img-badges{
  position:absolute;bottom:.75rem;left:.75rem;right:.75rem;
  display:flex;justify-content:space-between;align-items:flex-end;
}
.card-dist{
  background:rgba(255,255,255,0.22);backdrop-filter:blur(8px);
  color:white;border-radius:20px;
  padding:.2rem .6rem;font-size:.72rem;font-weight:700;
  border:1px solid rgba(255,255,255,0.3);
}
.status-badge{
  padding:.2rem .6rem;border-radius:20px;font-size:.7rem;font-weight:700;
  letter-spacing:.02em;
}
.s-closed{background:#c8102e;color:white;}
.s-open{background:#1a7f3c;color:white;}
.s-partial{background:#d97706;color:white;}

/* Card body */
.card-body{padding:1rem 1rem .9rem;flex:1;display:flex;flex-direction:column;gap:.5rem;}

.card-name{font-size:1rem;font-weight:700;color:var(--text);transition:color .15s;line-height:1.3;}

.card-meta{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;}
.card-meta-dot{color:var(--border);}

.card-stats{
  display:flex;gap:.6rem;margin-top:.25rem;
}
.cstat{
  flex:1;background:var(--bg);border-radius:8px;
  padding:.45rem .5rem;text-align:center;
}
.cstat-val{font-size:.92rem;font-weight:700;color:var(--text);line-height:1.2;}
.cstat-val.loading{color:var(--text-muted);font-size:.75rem;}
.cstat-lbl{font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:1px;}

.card-difficulty{
  display:flex;flex-wrap:wrap;gap:.3rem .6rem;
  padding:.4rem 0;border-top:1px solid var(--border);
  margin-top:.4rem;
}
.diff-item{
  display:flex;align-items:center;gap:.2rem;
  font-size:.65rem;color:var(--text-muted);white-space:nowrap;
}
.diff-icon{width:14px;height:14px;flex-shrink:0;}
.card-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:.4rem;border-top:1px solid var(--border);
}
.card-km{font-size:.78rem;color:var(--text-muted);margin-right:.4rem;}
.card-trails{font-size:.78rem;color:var(--text-muted);}
.card-trails strong{color:var(--text);}
.card-more{font-size:.75rem;color:var(--red);font-weight:600;display:flex;align-items:center;gap:.25rem;}

/* Resident toggle inside card */
.card-resident{
  display:flex;align-items:center;justify-content:space-between;
  gap:.5rem;
  padding:.55rem .7rem;
  border-radius:8px;
  border:1.5px solid var(--border);
  background:var(--bg);
  cursor:pointer;
  transition:border-color .15s, background .15s;
  user-select:none;
  margin-top:.1rem;
}
.card-resident:hover{border-color:#aaa;}
.card-resident.is-active{
  border-color:var(--green);
  background:var(--green-bg);
}
.card-resident-left{
  display:flex;align-items:center;gap:.5rem;
  font-size:.78rem;font-weight:600;
  color:var(--text-muted);
}
.card-resident.is-active .card-resident-left{color:var(--green);}
.card-resident-icon{font-size:.95rem;}

/* Mini toggle track inside card */
.mini-track{
  width:30px;height:17px;
  background:#ccc;border-radius:9px;
  position:relative;transition:background .15s;flex-shrink:0;
}
.mini-thumb{
  position:absolute;top:2px;left:2px;
  width:13px;height:13px;
  background:white;border-radius:50%;
  transition:left .15s;
  box-shadow:0 1px 3px rgba(0,0,0,0.2);
}
.card-resident.is-active .mini-track{background:var(--green);}
.card-resident.is-active .mini-thumb{left:15px;}

.card-resident-price{
  font-size:.8rem;font-weight:700;
  color:var(--text-muted);
  white-space:nowrap;
}
.card-resident.is-active .card-resident-price{color:var(--green);}
.card-price-orig{
  font-size:.72rem;color:#aaa;
  text-decoration:line-through;
  margin-right:.2rem;font-weight:400;
}

/* ── MODAL ── */
.modal-overlay{
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,0.55);
  backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  padding:1rem;
  opacity:0;pointer-events:none;
  transition:opacity .2s;
}
.modal-overlay.visible{opacity:1;pointer-events:all;}

.modal{
  background:var(--white);
  border-radius:18px;
  width:100%;max-width:680px;
  max-height:90vh;
  overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:var(--modal-shadow);
  transform:translateY(20px);
  transition:transform .25s;
}
.modal-overlay.visible .modal{transform:translateY(0);}

/* Fixed top bar — always visible, outside scroll */
.modal-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem 1rem .7rem 1.5rem;
  border-bottom:1px solid var(--border);
  background:var(--white);
  flex-shrink:0;
  gap:.75rem;
}
.modal-topbar-info{flex:1;min-width:0;}
.modal-resort-name{font-size:1rem;font-weight:800;color:var(--text);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.modal-resort-sub{font-size:.75rem;color:var(--text-muted);margin-top:.1rem;}
.modal-close{
  width:32px;height:32px;border-radius:50%;
  background:var(--border);border:none;color:var(--text);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;transition:background .15s;flex-shrink:0;
}
.modal-close:hover{background:#c0c0c5;}

/* Scroll container */
.modal-scroll{overflow-y:auto;flex:1;}

/* Hero image */
.modal-hero{
  height:200px;position:relative;overflow:hidden;
}
.modal-hero-bg{
  width:100%;height:100%;
  background-size:cover;background-position:center;
}
.modal-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,0.1) 0%,rgba(0,0,0,0.35) 100%);
}

.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;}

.modal-section{}
.modal-section-title{
  font-size:.7rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--text-muted);
  margin-bottom:.7rem;display:flex;align-items:center;gap:.4rem;
}

/* Weather in modal */
.modal-weather-row{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;}
.modal-weather-row .maps-btn{margin-left:auto;}
.maps-btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:1.5rem;text-decoration:none;
  width:2.4rem;height:2.4rem;border-radius:50%;
  background:var(--bg);border:1.5px solid var(--border);
  transition:background .15s,transform .15s;flex-shrink:0;
}
.maps-btn:hover{background:#e8f0fe;transform:scale(1.12);}
.modal-weather-main{display:flex;align-items:center;gap:.6rem;}
.mw-icon{font-size:2.5rem;line-height:1;}
.mw-temp{font-size:2rem;font-weight:800;}
.mw-desc{font-size:.82rem;color:var(--text-muted);margin-top:.1rem;}
.weather-pills{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem;}
.wpill{
  background:var(--bg);border:1px solid var(--border);
  border-radius:20px;padding:.2rem .65rem;font-size:.78rem;
}

/* Resident toggle inside modal */
.modal-resident-toggle{
  display:flex;align-items:center;justify-content:space-between;
  padding:.6rem .85rem;
  border-radius:9px;
  border:1.5px solid var(--border);
  background:var(--bg);
  cursor:pointer;
  transition:border-color .15s, background .15s;
  margin-bottom:.6rem;
  user-select:none;
}
.modal-resident-toggle:hover{border-color:#aaa;}
.modal-resident-toggle.is-active{border-color:var(--green);background:var(--green-bg);}
.modal-resident-left{
  display:flex;align-items:center;gap:.6rem;
  font-size:.85rem;font-weight:600;color:var(--text-muted);
}
.modal-resident-toggle.is-active .modal-resident-left{color:var(--green);}
.modal-resident-toggle.is-active .mini-track{background:var(--green);}
.modal-resident-toggle.is-active .mini-thumb{left:15px;}

/* Resident note */
.resident-note{
  background:var(--green-bg);border:1px solid #a7f3d0;
  border-radius:8px;padding:.55rem .85rem;
  font-size:.8rem;color:var(--green);font-weight:600;
  margin-bottom:.6rem;
}

.dynamic-note{
  background:#fff8e1;border:1px solid #ffe082;
  border-radius:8px;padding:.55rem .85rem;
  font-size:.8rem;color:#795548;
  margin-bottom:.6rem;
}
.dynamic-note a{color:#795548;font-weight:600;}

/* Price table */
.price-tbl{width:100%;border-collapse:collapse;font-size:.85rem;}
.price-tbl tr{border-bottom:1px solid var(--border);}
.price-tbl tr:last-child{border-bottom:none;}
.price-tbl td{padding:.45rem 0;}
.price-tbl td:last-child{text-align:right;font-weight:700;}
.p-orig{color:var(--text-muted);text-decoration:line-through;font-size:.78rem;font-weight:400;margin-right:.35rem;}
.p-disc{color:var(--green);}

/* Trails grid */
.trails-4{display:grid;grid-template-columns:1fr 1fr;gap:.35rem;}
.trail-row{
  display:flex;align-items:center;gap:.4rem;
  background:var(--bg);border:1px solid var(--border);
  border-radius:8px;padding:.35rem .5rem;font-size:.82rem;
}
.trail-icon{width:24px;height:24px;flex-shrink:0;}
.trail-count{margin-left:auto;font-weight:700;color:var(--text-muted);}

/* Parking */
.park-rows{display:flex;flex-direction:column;gap:.4rem;}
.park-row{
  background:var(--bg);border:1px solid var(--border);
  border-radius:8px;padding:.55rem .75rem;
  display:flex;justify-content:space-between;align-items:center;
  gap:.5rem;flex-wrap:wrap;font-size:.83rem;
}
.park-name{font-weight:500;flex:1;min-width:120px;}
.park-price{font-weight:700;color:var(--red);}
.park-spots{color:var(--text-muted);font-size:.76rem;}
.park-btns{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.25rem;}
.trail-btns{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem;}
.trails-region-note{font-size:.78rem;color:var(--text-muted);margin-top:.5rem;padding:.4rem .6rem;background:var(--bg);border-radius:6px;}
.trail-notes{display:flex;flex-direction:column;gap:.35rem;margin-top:.6rem;}
.trail-note-item{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--text-muted);}
.park-price-link{color:var(--red);font-weight:700;font-size:.83rem;text-decoration:underline;}
.park-link-btn{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.78rem;font-weight:600;text-decoration:none;
  padding:.35rem .75rem;border-radius:20px;
  border:1.5px solid var(--border);background:var(--white);
  color:var(--text);transition:background .15s,border-color .15s;
}
.park-link-btn:hover{background:var(--bg);border-color:var(--red);color:var(--red);}

/* Modal actions */
.modal-actions{display:flex;gap:.75rem;padding-top:.25rem;}
.btn{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.65rem 1.3rem;border-radius:9px;
  text-decoration:none;font-size:.85rem;font-weight:600;
  transition:all .15s;border:none;cursor:pointer;
}
.btn-primary{background:var(--red);color:white;}
.btn-primary:hover{background:var(--red-hover);}
.btn-secondary{background:var(--white);color:var(--text);border:1.5px solid var(--border);}
.btn-secondary:hover{border-color:var(--red);color:var(--red);}

/* Spinner */
.spinner{
  display:inline-block;width:14px;height:14px;
  border:2px solid var(--border);border-top-color:var(--red);
  border-radius:50%;animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .resort-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:600px){
  .resort-grid{grid-template-columns:1fr;}
  .header-inner{height:auto;padding:.6rem 1rem;flex-wrap:nowrap;gap:.5rem;}
  .header-right{flex-shrink:0;}
  .lang-btn{padding:.25rem .35rem;}
  .lang-btn img{width:20px;height:14px;}
  .graubuenden-logo{height:1.8rem;}
  .logo-text h1{font-size:1.1rem;}
  .logo-text p{font-size:.65rem;}
  .modal{border-radius:14px 14px 0 0;max-height:95vh;}
  .modal-overlay{align-items:flex-end;padding:0;}
  .toolbar{flex-direction:column;align-items:flex-start;padding:1rem 1rem .5rem;}
  main{padding:0 1rem 3rem;}
  .trails-4{grid-template-columns:1fr;}
  .modal-actions{flex-direction:column;}
}
