/* Budapest 2026 PWA — Design System */
:root {
  --primary: #1e293b;
  --primary-light: #334155;
  --secondary: #0f766e;
  --secondary-light: #ccfbf1;
  --accent: #c2410c;
  --accent-light: #ffedd5;
  --gold: #b45309;
  --bg-light: #faf8f5;
  --bg-card: #ffffff;
  --text-dark: #1e293b;
  --text-muted: #64748b;
  --border: rgba(30,41,59,0.08);
  --hu-red: #ce2939;
  --hu-green: #477050;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.05);
  --shadow-md: 0 4px 6px -1px rgba(0,0,0,.08), 0 2px 4px -2px rgba(0,0,0,.04);
  --shadow-lg: 0 10px 25px -5px rgba(0,0,0,.08), 0 8px 10px -6px rgba(0,0,0,.04);
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --transition: all .25s cubic-bezier(.4,0,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{overflow-x:hidden}
body{
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  background:var(--bg-light);
  color:var(--text-dark);
  line-height:1.6;
  padding-bottom:80px;
  font-size:16px;
}
h1,h2,h3,h4{font-family:'Outfit',system-ui,sans-serif;font-weight:700;color:var(--primary)}
a{color:var(--secondary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--accent)}
img{max-width:100%;display:block}

/* HOME HEADER con immagine di sfondo dietro al titolo */
.app-header.with-bg{
  background-color:#0f172a;
  background-size:cover;
  background-position:center;
  position:relative;
  border-bottom:none;
}
.app-header.with-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,23,42,.25) 0%,rgba(15,23,42,.55) 65%,rgba(15,23,42,.85) 100%);
  z-index:1;pointer-events:none;
}
.app-header.with-bg .hungary-ribbon{position:relative;z-index:3}
.app-header.with-bg .header-container{
  position:relative;z-index:2;
  padding:34px 20px 28px;
  text-align:center;
}
.app-header.with-bg .app-title-wrapper i{color:#fde68a;font-size:1.5rem}
.app-header.with-bg .app-title-wrapper h1{
  color:#fff;font-size:1.85rem;
  text-shadow:0 2px 12px rgba(0,0,0,.6);
  letter-spacing:.5px;
}
.app-header.with-bg .header-container > p{
  color:#fff;opacity:.95;font-weight:600;
  text-shadow:0 1px 6px rgba(0,0,0,.5);
  font-size:.85rem;margin-top:6px;
}
.app-header.with-bg .header-container > p button{color:#fde68a}
.app-header.with-bg .header-meta{
  display:flex;justify-content:center;flex-wrap:wrap;gap:10px;
  margin-top:14px;
}
.app-header.with-bg .header-meta span{
  background:rgba(255,255,255,.18);backdrop-filter:blur(8px);
  color:#fff;padding:5px 12px;border-radius:30px;
  font-size:.75rem;font-weight:700;
  display:inline-flex;align-items:center;gap:6px;
  border:1px solid rgba(255,255,255,.25);
}
.app-header.with-bg .header-meta span i{color:#fde68a;font-size:.85rem}
.app-header.with-bg [data-user-email]{color:#fde68a}
@media (min-width:900px){
  .app-header.with-bg .header-container{padding:60px 20px 50px}
  .app-header.with-bg .app-title-wrapper h1{font-size:2.6rem}
  .app-header.with-bg .header-container > p{font-size:1rem}
}

/* HEADER */
.app-header{background:var(--bg-card);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100;border-bottom:1px solid var(--border)}
.hungary-ribbon{display:flex;height:5px}
.ribbon-red{flex:1;background:var(--hu-red)}
.ribbon-white{flex:1;background:#fff}
.ribbon-green{flex:1;background:var(--hu-green)}
.header-container{padding:16px 20px;text-align:center}
.app-title-wrapper{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:4px}
.app-title-wrapper h1{font-size:1.4rem}
.app-title-wrapper i{color:var(--secondary);font-size:1.3rem}
.header-container p{font-size:.8rem;color:var(--text-muted);font-weight:500}
.back-link{position:absolute;left:16px;top:50%;transform:translateY(-30%);color:var(--secondary);font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:4px}

/* CONTAINER */
.container{max-width:1100px;margin:0 auto;padding:16px}
.container.narrow{max-width:760px}

/* CARDS */
.card{background:var(--bg-card);border-radius:var(--radius-md);padding:18px;margin-bottom:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.card-title{font-size:1.05rem;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.card-title i{color:var(--secondary)}

/* QUICK INFO */
.quick-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
.info-box{background:var(--bg-card);padding:12px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;gap:10px;align-items:center;border:1px solid var(--border)}
.info-box i{font-size:1.4rem;color:var(--secondary);width:28px;text-align:center}
.info-box span{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.info-box p{font-size:.9rem;font-weight:700;color:var(--primary);line-height:1.2;margin-top:2px}

/* DAY CARDS (home) */
.day-grid{display:grid;grid-template-columns:1fr;gap:12px}
.day-card{background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border);display:block;color:inherit;transition:var(--transition);position:relative}
.day-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.day-card-hero{height:140px;background-size:cover;background-position:center;position:relative}
.day-card-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.7))}
.day-card-label{position:absolute;top:10px;left:10px;background:var(--accent);color:#fff;padding:4px 10px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;z-index:2}
.day-card-date{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.95);color:var(--primary);padding:4px 10px;border-radius:20px;font-size:.7rem;font-weight:700;z-index:2}
.day-card-title{position:absolute;bottom:10px;left:14px;right:14px;color:#fff;font-size:1.1rem;font-weight:700;z-index:2;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.day-card-body{padding:12px 14px}
.day-card-body p{font-size:.85rem;color:var(--text-muted);margin-bottom:8px}
.day-card-cta{color:var(--secondary);font-weight:700;font-size:.85rem;display:flex;align-items:center;gap:6px}

/* TIMELINE */
.timeline{position:relative;padding-left:24px;margin-top:14px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--secondary-light)}
.timeline-item{position:relative;margin-bottom:20px}
.timeline-marker{position:absolute;left:-22px;top:6px;width:14px;height:14px;background:var(--secondary);border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 2px var(--secondary)}
.timeline-time{font-size:.75rem;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.5px;display:inline-flex;align-items:center;gap:5px}
.timeline-title{font-size:1.05rem;margin:4px 0 6px}
.timeline-desc{font-size:.9rem;color:var(--text-dark);margin-bottom:10px}
.timeline-desc strong{color:var(--primary)}

/* BUTTONS */
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--radius-sm);font-size:.8rem;font-weight:700;text-decoration:none;border:1px solid transparent;transition:var(--transition);cursor:pointer}
.btn-map{background:var(--secondary);color:#fff}
.btn-map:hover{background:var(--primary);color:#fff}
.btn-ticket{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}
.btn-ticket:hover{background:var(--accent);color:#fff}
.btn-review{background:#f0f3f5;color:#1F2937;border-color:#d8dde2}
.btn-review:hover{background:#1F2937;color:#fff}
.btn-web{background:var(--secondary-light);color:var(--secondary);border-color:var(--secondary)}
.btn-web:hover{background:var(--secondary);color:#fff}
.btn-primary{background:var(--accent);color:#fff;padding:12px 22px;font-size:.95rem;border-radius:var(--radius-md);width:100%;justify-content:center}
.btn-primary:hover{background:#9a3309;color:#fff}

/* TIPS */
.tip{padding:10px 12px;border-radius:var(--radius-sm);font-size:.85rem;margin-top:8px;display:flex;gap:10px;align-items:flex-start;border-left:3px solid}
.tip.baby{background:#fff7ed;border-color:#fb923c;color:#7c2d12}
.tip.bring{background:#ecfeff;border-color:#06b6d4;color:#155e75}
.tip.warn{background:#fef2f2;border-color:#ef4444;color:#7f1d1d}
.tip.info{background:#eff6ff;border-color:#3b82f6;color:#1e3a8a}
.tip i{margin-top:2px}

/* HERO BANNERS for day pages */
.hero{position:relative;height:230px;background-size:cover;background-position:center;border-radius:0 0 var(--radius-lg) var(--radius-lg);margin-bottom:14px;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(0,0,0,.75) 100%)}
.hero-content{position:absolute;bottom:0;left:0;right:0;padding:20px;color:#fff;z-index:2}
.hero-eyebrow{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;opacity:.9}
.hero-title{font-size:1.6rem;color:#fff;line-height:1.15;margin-top:4px}
.hero-meta{font-size:.85rem;margin-top:6px;opacity:.95;display:flex;gap:14px;flex-wrap:wrap}
.hero-meta span{display:flex;align-items:center;gap:5px}

/* IMAGE GALLERIES */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:10px 0}
.gallery img{width:100%;height:120px;object-fit:cover;border-radius:var(--radius-sm)}
.gallery.single img{height:200px}
.gallery.triple{grid-template-columns:repeat(3,1fr)}
.gallery.triple img{height:100px}

/* TRANSPORT BLOCK */
.transport{background:linear-gradient(135deg,#ecfeff,#cffafe);border-radius:var(--radius-md);padding:14px;margin:10px 0;border:1px solid #67e8f9}
.transport h5{color:#0e7490;font-size:.95rem;display:flex;align-items:center;gap:8px;margin-bottom:8px}
.transport ol{margin-left:20px;font-size:.85rem;line-height:1.7}
.transport ol li{padding:3px 0}
.transport .stop{font-weight:700;color:#0e7490}

/* TICKET BLOCK */
.ticket-info{background:var(--accent-light);border:1px solid #fdba74;border-radius:var(--radius-md);padding:14px;margin:10px 0}
.ticket-info h5{color:var(--accent);margin-bottom:6px;display:flex;gap:8px;align-items:center}
.ticket-info p{font-size:.85rem;color:#7c2d12}
.ticket-info .price{font-weight:700;color:var(--accent);font-size:.95rem;margin:4px 0}

/* EQUIPMENT */
.equipment-box{background:#fff7ed;border:1px solid #fed7aa;border-radius:var(--radius-md);padding:14px;margin-bottom:14px}
.equipment-box h5{color:var(--accent);margin-bottom:8px;font-size:.95rem}
.equipment-list{list-style:none}
.equipment-list li{padding:4px 0}
.equipment-list label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.85rem;color:#7c2d12}
.equipment-list input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}

/* HOTEL */
.hotel-hero{height:240px;background-size:cover;background-position:center;border-radius:var(--radius-md);position:relative;overflow:hidden;margin-bottom:14px}
.hotel-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.6))}
.hotel-hero-content{position:absolute;bottom:0;left:0;right:0;padding:18px;color:#fff;z-index:2}
.hotel-hero-content h2{color:#fff;font-size:1.4rem;line-height:1.2}
.hotel-rating-row{display:flex;gap:10px;margin-top:6px;font-size:.8rem;flex-wrap:wrap}
.rating-pill{background:rgba(255,255,255,.95);color:var(--primary);padding:3px 10px;border-radius:20px;font-weight:700}
.rating-pill.gold{background:var(--gold);color:#fff}

.room-card{display:flex;justify-content:space-between;align-items:center;padding:14px;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:10px}
.room-card-left h4{font-size:1rem;margin-bottom:2px}
.room-card-left p{font-size:.8rem;color:var(--text-muted)}
.room-card-price{font-size:1.3rem;font-weight:700;color:var(--accent);font-family:'Outfit',sans-serif}
.room-card-price small{font-size:.7rem;color:var(--text-muted);font-weight:500;display:block;text-align:right}

.fact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:10px 0}
.fact{background:#f8fafc;padding:10px;border-radius:var(--radius-sm);border:1px solid var(--border)}
.fact .label{font-size:.7rem;text-transform:uppercase;color:var(--text-muted);font-weight:700;letter-spacing:.5px}
.fact .value{font-size:.9rem;font-weight:700;color:var(--primary)}

.amenity-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:10px 0}
.amenity{display:flex;gap:8px;align-items:center;font-size:.85rem;padding:6px 0}
.amenity i{color:var(--secondary);width:18px;text-align:center}

.contact-block{background:linear-gradient(135deg,#ecfeff,#fff);border:1px solid #67e8f9;border-radius:var(--radius-md);padding:14px;margin-top:10px}
.contact-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.9rem}
.contact-row:last-child{border-bottom:none}
.contact-row i{color:var(--secondary);width:22px;text-align:center;font-size:1rem}
.contact-row a{color:var(--secondary);font-weight:600;word-break:break-all}

/* MAP */
#map{width:100%;height:75vh;min-height:500px;border-radius:var(--radius-md);box-shadow:var(--shadow-md);border:1px solid var(--border)}
.map-legend{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0;font-size:.8rem}
.legend-item{display:flex;align-items:center;gap:6px;background:var(--bg-card);padding:5px 10px;border-radius:20px;border:1px solid var(--border)}
.legend-dot{width:14px;height:14px;border-radius:50%}

/* BOTTOM NAV */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:8px 0 calc(8px + env(safe-area-inset-bottom));box-shadow:0 -4px 12px rgba(0,0,0,.06);z-index:50}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:.7rem;color:var(--text-muted);font-weight:600;padding:4px 8px;border-radius:8px;transition:var(--transition);flex:1;max-width:90px}
.nav-item i{font-size:1.2rem}
.nav-item.active{color:var(--secondary)}
.nav-item:hover{color:var(--accent)}

/* FOOTER */
.app-footer{text-align:center;padding:20px;color:var(--text-muted);font-size:.8rem;font-weight:500}

/* LOGIN */
.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#0f766e 0%,#1e293b 100%)}
.login-card{background:#fff;border-radius:var(--radius-lg);padding:30px 24px;max-width:380px;width:100%;box-shadow:var(--shadow-lg);text-align:center}
.login-card .logo{font-size:2.5rem;color:var(--accent);margin-bottom:8px}
.login-card h1{font-size:1.4rem;margin-bottom:4px}
.login-card .subtitle{color:var(--text-muted);font-size:.85rem;margin-bottom:20px}
.login-card input{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;margin-bottom:12px;outline:none;transition:var(--transition)}
.login-card input:focus{border-color:var(--secondary);box-shadow:0 0 0 3px rgba(15,118,110,.1)}
.login-error{background:#fef2f2;color:#7f1d1d;font-size:.8rem;padding:10px;border-radius:var(--radius-sm);margin-bottom:12px;border:1px solid #fecaca;display:none}
.login-error.visible{display:block}
.login-note{font-size:.75rem;color:var(--text-muted);margin-top:14px;line-height:1.5}
.logout-btn{background:transparent;border:none;color:var(--text-muted);font-size:.75rem;font-weight:600;cursor:pointer;padding:4px 8px}
.logout-btn:hover{color:var(--accent)}

/* WIDGETS */
.weather-widget,.currency-widget{margin-bottom:14px}
.weather-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.weather-current{display:flex;align-items:center;gap:14px;padding:8px 0}
.weather-icon-large{font-size:2.6rem;color:var(--accent)}
.weather-temp{font-size:1.8rem;font-weight:700;font-family:'Outfit',sans-serif;color:var(--primary)}
.weather-info-text{font-size:.78rem;color:var(--text-muted)}
.weather-forecast{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:10px;border-top:1px solid var(--border);padding-top:10px}
.forecast-day{text-align:center;font-size:.75rem;color:var(--text-muted)}
.forecast-day i{font-size:1.2rem;color:var(--accent);margin:4px 0}
.forecast-day p{font-weight:700;color:var(--primary);font-size:.75rem}

.currency-box{display:flex;align-items:center;gap:10px;background:#f8fafc;padding:12px;border-radius:var(--radius-sm)}
.currency-input-group{flex:1;display:flex;flex-direction:column;gap:4px}
.currency-input-group input{padding:8px 10px;font-size:.95rem;font-weight:700;border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;width:100%}
.currency-input-group input:focus{border-color:var(--secondary)}
.currency-label{font-size:.7rem;color:var(--text-muted);font-weight:700;text-transform:uppercase}
.currency-divider{color:var(--secondary);font-size:1.2rem;padding:0 2px;cursor:pointer}
.rate-info{font-size:.75rem;color:var(--text-muted);margin-top:8px;text-align:center}

/* BUDGET */
.budget-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--border);font-size:.9rem}
.budget-row:last-child{border-bottom:none;font-weight:700;color:var(--primary);font-size:1rem;padding-top:12px;border-top:2px solid var(--primary);margin-top:6px}

/* SIM CARDS */
.sim-grid{display:grid;grid-template-columns:1fr;gap:10px}
.sim-card{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px}
.sim-card h4{font-size:1rem;color:var(--secondary);margin-bottom:4px}
.sim-card .price-tag{display:inline-block;background:var(--accent);color:#fff;padding:2px 8px;border-radius:20px;font-size:.75rem;font-weight:700;margin-bottom:6px}
.sim-card p{font-size:.85rem;color:var(--text-dark);margin-bottom:6px}

/* RESPONSIVE */
@media (min-width:640px){
  .quick-info-grid{grid-template-columns:repeat(4,1fr)}
  .day-grid{grid-template-columns:repeat(2,1fr)}
  .gallery img{height:160px}
  .fact-grid{grid-template-columns:repeat(3,1fr)}
  .amenity-grid{grid-template-columns:repeat(3,1fr)}
  .sim-grid{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:900px){
  .day-grid{grid-template-columns:repeat(3,1fr)}
  .fact-grid{grid-template-columns:repeat(4,1fr)}
  .amenity-grid{grid-template-columns:repeat(4,1fr)}
  .sim-grid{grid-template-columns:repeat(3,1fr)}
  .gallery img{height:200px}
  .gallery.triple img{height:170px}
  .hero{height:300px;border-radius:0 0 24px 24px}
  .hero-title{font-size:2rem}
  .container{padding:24px}
  .card{padding:22px}
  /* Layout 2 colonne per pagine ricche */
  .two-col{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;align-items:start}
  .two-col > .card{margin-bottom:0}
}
@media (min-width:1100px){
  .gallery img{height:230px}
}

/* HIDE while auth check */
body.auth-checking{visibility:hidden}

/* DAY NAVIGATION (prev/next between days) */
.day-nav{display:flex;justify-content:space-between;align-items:stretch;gap:10px;margin:20px 0 14px}
.day-nav a, .day-nav .placeholder{
  flex:1;display:flex;align-items:center;gap:10px;
  padding:14px 16px;background:var(--bg-card);
  border:1px solid var(--border);border-radius:var(--radius-md);
  text-decoration:none;color:var(--text-dark);
  transition:var(--transition);min-height:64px;
  box-shadow:var(--shadow-sm);
}
.day-nav a:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--secondary)}
.day-nav .placeholder{opacity:.45;cursor:default}
.day-nav .arrow{font-size:1.3rem;color:var(--secondary);flex-shrink:0}
.day-nav .meta{display:flex;flex-direction:column;min-width:0;flex:1}
.day-nav .meta span{font-size:.65rem;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);font-weight:700}
.day-nav .meta p{font-size:.85rem;font-weight:700;color:var(--primary);margin-top:2px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.day-nav .next{text-align:right;flex-direction:row-reverse}
.day-nav .next .meta{align-items:flex-end}

/* BOARDING PASS CARD */
.boarding-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width:640px){.boarding-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.boarding-grid{grid-template-columns:repeat(3,1fr)}}
.boarding-pass{
  position:relative;
  background:linear-gradient(135deg,#0f766e 0%,#134e4a 100%);
  border-radius:var(--radius-md);overflow:hidden;
  color:#fff;box-shadow:var(--shadow-md);
}
.boarding-pass.return{background:linear-gradient(135deg,#c2410c 0%,#9a3309 100%)}
.boarding-pass-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 16px;background:rgba(0,0,0,.15);
  font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;
}
.boarding-pass-head .pass-type i{margin-right:5px}
.boarding-pass-route{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 16px 12px;gap:8px;
}
.boarding-pass-route .city{text-align:center}
.boarding-pass-route .city .iata{font-family:'Outfit',sans-serif;font-size:1.6rem;font-weight:700;color:#fff;line-height:1}
.boarding-pass-route .city .city-name{font-size:.7rem;opacity:.85;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
.boarding-pass-route .plane{font-size:1.2rem;opacity:.7}
.boarding-pass-route .plane.back{transform:scaleX(-1)}
.boarding-pass-body{padding:0 16px 14px}
.boarding-pass-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.75rem;border-bottom:1px dashed rgba(255,255,255,.2);padding-bottom:6px}
.boarding-pass-row .label{opacity:.7;font-weight:600;text-transform:uppercase;letter-spacing:.4px;font-size:.65rem}
.boarding-pass-row .value{font-weight:700}
.boarding-pass-family{
  background:rgba(0,0,0,.2);padding:12px 16px;
  font-size:.78rem;border-top:2px dashed rgba(255,255,255,.3);
}
.boarding-pass-family strong{display:block;font-size:.85rem;margin-bottom:3px}
.boarding-pass-placeholder{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-12deg);
  background:rgba(255,255,255,.95);color:#0f766e;
  padding:8px 18px;border-radius:8px;font-weight:800;font-size:.8rem;
  letter-spacing:1px;text-transform:uppercase;
  border:2px dashed #0f766e;pointer-events:none;
}
.boarding-pass.return .boarding-pass-placeholder{color:#c2410c;border-color:#c2410c}
