*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
:root {
    --red: #D72638; --red-deep: #A31D2B; --red-bright: #FF3A4F;
    --cream: #FAF9F6; --ink: #0A0A0A; --ink-80: #2A2A2A; --ink-60: #555;
    --ink-40: #888; --ink-20: #BBB; --ink-10: #DDD; --ink-05: #EEEDE9;
    --serif: 'Instrument Serif', Georgia, serif; --sans: 'DM Sans', system-ui, sans-serif;
}
body { font-family: var(--sans); color: var(--ink); background: var(--cream); -webkit-font-smoothing: antialiased; overflow-x: hidden; }
.grain{position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:0.3;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}
.reveal{opacity:0;transform:translateY(32px);transition:opacity 0.7s cubic-bezier(0.22,1,0.36,1),transform 0.7s cubic-bezier(0.22,1,0.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:0.1s}.reveal-delay-2{transition-delay:0.2s}.reveal-delay-3{transition-delay:0.3s}
.topnav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;transition:background 0.3s,box-shadow 0.3s}
.topnav.scrolled{background:rgba(250,249,246,0.92);backdrop-filter:blur(16px);box-shadow:0 1px 0 var(--ink-10)}
.topnav-logo{display:flex;align-items:center;gap:0.6rem;text-decoration:none;color:var(--ink)}
.topnav-logo .cross{width:30px;height:30px;background:var(--red);border-radius:6px;display:grid;place-items:center;color:white;font-weight:700;font-size:1.3rem;line-height:1}
.topnav-logo .wordmark{font-weight:700;font-size:0.95rem;letter-spacing:-0.01em}
.topnav-right{display:flex;align-items:center;gap:.5rem}
.topnav-cta{font-size:0.8rem;font-weight:600;color:var(--ink-60);text-decoration:none;padding:0.5rem 1rem;border:1px solid var(--ink-10);border-radius:100px;transition:all 0.2s}
.topnav-cta:hover{border-color:var(--red);color:var(--red)}
.lang-sw{display:flex;align-items:center;gap:0;background:var(--ink-05);border-radius:8px;overflow:hidden;border:1px solid var(--ink-10)}
.lang-sw a{color:var(--ink-60);text-decoration:none;padding:.4rem .7rem;font-size:.8rem;font-weight:600;transition:all .15s;border-right:1px solid var(--ink-10)}
.lang-sw a:last-child{border-right:none}
.lang-sw a:hover{color:var(--red);background:white}
.lang-sw a.active{color:white;background:var(--ink)}
.hero{min-height:100vh;min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:7rem 2rem 3rem;position:relative}
.hero::before{content:'+';position:absolute;top:12%;right:8%;font-size:20rem;font-weight:100;color:var(--red);opacity:0.04;line-height:1;pointer-events:none}
.hero-eyebrow{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.75rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);margin-bottom:2rem}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:24px;height:1px;background:var(--red)}
.hero h1{font-family:var(--serif);font-size:clamp(2.75rem,7vw,5.5rem);font-weight:400;line-height:1.05;letter-spacing:-0.03em;color:var(--ink);max-width:820px;margin-bottom:1.5rem}
.hero h1 em{font-style:italic;color:var(--red)}
.hero-sub{font-size:1.1rem;color:var(--ink-40);max-width:460px;margin:0 auto 3rem;line-height:1.6}
.search-wrap{position:relative;width:100%;max-width:560px;margin:0 auto 4rem;z-index:10}
.search-box{display:flex;align-items:center;background:var(--cream);border:2px solid var(--ink);border-radius:100px;overflow:hidden;transition:border-color 0.2s,box-shadow 0.2s}
.search-box:focus-within{border-color:var(--red);box-shadow:0 0 0 4px rgba(215,38,56,0.1)}
.search-box .s-icon{flex-shrink:0;margin-left:1.25rem;color:var(--ink-40)}
.search-box .s-icon svg{width:20px;height:20px;display:block}
.search-input{flex:1;border:none;background:none;padding:1.1rem 0.75rem;font-size:1rem;font-family:var(--sans);color:var(--ink);outline:none}
.search-input::placeholder{color:var(--ink-20)}
.search-btn{flex-shrink:0;background:var(--red);color:white;border:none;padding:0.85rem 1.75rem;margin:0.35rem;border-radius:100px;font-size:0.875rem;font-weight:600;font-family:var(--sans);cursor:pointer;transition:background 0.15s}
.search-btn:hover{background:var(--red-deep)}
.autocomplete-list{position:absolute;top:calc(100% + 8px);left:0;right:0;background:white;border:1px solid var(--ink-10);border-radius:16px;box-shadow:0 24px 64px rgba(0,0,0,0.12);overflow:hidden;display:none;z-index:100;max-height:400px;overflow-y:auto}
.autocomplete-list.visible{display:block}
.autocomplete-item{display:flex;align-items:center;gap:0.85rem;padding:0.85rem 1.25rem;cursor:pointer;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--ink-05);transition:background 0.1s}
.autocomplete-item:last-child{border-bottom:none}
.autocomplete-item:hover,.autocomplete-item.active{background:#FFF5F5}
.autocomplete-item .pin{width:36px;height:36px;background:var(--ink-05);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--ink-40)}
.autocomplete-item:hover .pin,.autocomplete-item.active .pin{background:#FFE5E8;color:var(--red)}
.autocomplete-item .pin svg{width:16px;height:16px}
.autocomplete-item .info{flex:1}
.autocomplete-item .name{font-weight:600;font-size:0.9375rem}
.autocomplete-item .name mark{background:none;color:var(--red);font-weight:700}
.autocomplete-item .canton-label{font-size:0.75rem;color:var(--ink-40)}
.autocomplete-item .arrow{color:var(--ink-20);flex-shrink:0;transition:transform 0.15s,color 0.15s}
.autocomplete-item:hover .arrow{transform:translateX(3px);color:var(--red)}
.autocomplete-item .arrow svg{width:16px;height:16px}
.autocomplete-empty{padding:1.5rem;text-align:center;color:var(--ink-40)}
.carousel-section{padding:0 0 2rem;position:relative}
.carousel-wrap{overflow:hidden;mask-image:linear-gradient(90deg,transparent 0%,black 6%,black 94%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0%,black 6%,black 94%,transparent 100%)}
.carousel-track{display:flex;gap:0.5rem;animation:marquee 40s linear infinite;width:max-content}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.carousel-track:hover{animation-play-state:paused}
.c-pill{flex-shrink:0;display:inline-flex;align-items:center;gap:0.4rem;padding:0.5rem 1rem;background:transparent;border:1px solid var(--ink-10);border-radius:100px;text-decoration:none;color:var(--ink);font-size:0.8125rem;font-weight:500;white-space:nowrap;transition:all 0.2s}
.c-pill:hover{border-color:var(--red);color:var(--red);background:#FFF5F5}
.c-pill .c-dot{width:6px;height:6px;background:var(--ink-20);border-radius:50%;transition:background 0.2s}
.c-pill:hover .c-dot{background:var(--red)}
.stats-strip{background:var(--ink);color:white;overflow:hidden}
.stats-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr)}
.stat-block{padding:3rem 2rem;text-align:center;position:relative}
.stat-block:not(:last-child)::after{content:'';position:absolute;right:0;top:25%;bottom:25%;width:1px;background:rgba(255,255,255,0.12)}
.stat-val{font-family:var(--serif);font-size:clamp(2rem,4vw,3.25rem);font-weight:400;letter-spacing:-0.03em;line-height:1;margin-bottom:0.35rem}
.stat-val .red{color:var(--red-bright)}
.stat-lbl{font-size:0.8rem;color:rgba(255,255,255,0.5);letter-spacing:0.04em;text-transform:uppercase;font-weight:500}
.how-section{padding:6rem 2rem;max-width:1080px;margin:0 auto}
.how-header{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;margin-bottom:4rem;flex-wrap:wrap}
.how-header h2{font-family:var(--serif);font-size:clamp(1.75rem,4vw,2.75rem);font-weight:400;letter-spacing:-0.02em;line-height:1.15;max-width:400px}
.how-header p{font-size:0.9rem;color:var(--ink-40);max-width:320px;line-height:1.6}
.how-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.h-step{padding:2.5rem 2rem;border-top:2px solid var(--ink-10);position:relative;transition:border-color 0.3s}
.h-step:hover{border-top-color:var(--red)}
.h-step-num{font-family:var(--serif);font-size:4rem;color:var(--ink-05);line-height:1;margin-bottom:1.25rem;transition:color 0.3s}
.h-step:hover .h-step-num{color:rgba(215,38,56,0.15)}
.h-step h3{font-size:1.05rem;font-weight:700;margin-bottom:0.5rem;letter-spacing:-0.01em}
.h-step p{font-size:0.875rem;color:var(--ink-40);line-height:1.6}
.cities-section{padding:0 2rem 6rem;max-width:1080px;margin:0 auto}
.cities-header{margin-bottom:3rem}
.cities-header h2{font-family:var(--serif);font-size:clamp(1.75rem,4vw,2.75rem);font-weight:400;letter-spacing:-0.02em;margin-bottom:0.5rem}
.cities-header p{color:var(--ink-40);font-size:0.95rem}
.cities-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto auto;gap:1rem}
.city-tile:nth-child(1),.city-tile:nth-child(2){grid-row:span 1;min-height:280px}
.city-tile:nth-child(1){grid-column:span 2}.city-tile:nth-child(2){grid-column:span 2}
.city-tile{position:relative;display:flex;flex-direction:column;justify-content:flex-end;border-radius:12px;overflow:hidden;text-decoration:none;color:white;min-height:180px}
.city-tile .city-bg{position:absolute;inset:0}
.city-bg img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.6s cubic-bezier(0.22,1,0.36,1)}
.city-tile:hover .city-bg img{transform:scale(1.06)}
.city-tile .overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.75) 0%,rgba(0,0,0,0.05) 60%);z-index:1}
.tile-content{position:relative;z-index:2;padding:1.25rem 1.5rem}
.tile-name{font-family:var(--serif);font-size:1.35rem;line-height:1.2;margin-bottom:0.15rem}
.city-tile:nth-child(1) .tile-name,.city-tile:nth-child(2) .tile-name{font-size:1.75rem}
.tile-canton{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.08em;color:rgba(255,255,255,0.6);font-weight:500}
.tile-arrow{position:absolute;top:1rem;right:1rem;z-index:2;width:32px;height:32px;background:rgba(255,255,255,0.12);backdrop-filter:blur(4px);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:translate(-4px,4px);transition:all 0.3s cubic-bezier(0.22,1,0.36,1)}
.city-tile:hover .tile-arrow{opacity:1;transform:translate(0,0)}
.tile-arrow svg{width:14px;height:14px}
.source-bar{border-top:1px solid var(--ink-10);padding:1.5rem 2rem;display:flex;align-items:center;justify-content:center;gap:0.6rem;font-size:0.8rem;color:var(--ink-40)}
.source-bar .bag-mark{display:inline-flex;align-items:center;gap:0.3rem;font-weight:600;color:var(--ink-60)}
.source-bar svg{width:14px;height:14px}
footer{background:var(--ink);color:rgba(255,255,255,0.4);padding:3rem 2rem}
.footer-inner{max-width:1080px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-left{display:flex;align-items:center;gap:0.6rem}
.footer-left .f-cross{width:24px;height:24px;background:var(--red);border-radius:4px;display:grid;place-items:center;color:white;font-weight:700;font-size:1rem;line-height:1}
.footer-left span{font-size:0.8rem}
.footer-links{display:flex;gap:2rem}
.footer-links a{font-size:0.8rem;color:rgba(255,255,255,0.4);text-decoration:none;transition:color 0.15s}
.footer-links a:hover{color:white}
.footer-copy{width:100%;text-align:center;font-size:0.7rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,0.08);color:rgba(255,255,255,0.25)}
.alert-section{max-width:1080px;margin:0 auto;padding:0 2rem 4rem}
.alert-home{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);border-radius:16px;padding:3rem;text-align:center;color:white}
.alert-home h2{font-family:var(--serif);font-size:clamp(1.3rem,3vw,1.8rem);font-weight:400;margin-bottom:.5rem}
.alert-home h2 span{color:var(--red-bright)}
.alert-home>p{font-size:.9rem;color:rgba(255,255,255,.55);max-width:520px;margin:0 auto 1.5rem;line-height:1.6}
.alert-home .alert-form{display:flex;max-width:480px;margin:0 auto;gap:.5rem}
.alert-home .alert-form input[type="email"]{flex:1;border:none;background:rgba(255,255,255,.1);border-radius:8px;padding:.85rem 1.25rem;font-size:.9rem;font-family:var(--sans);color:white;outline:none;transition:background .15s}
.alert-home .alert-form input[type="email"]::placeholder{color:rgba(255,255,255,.35)}
.alert-home .alert-form input[type="email"]:focus{background:rgba(255,255,255,.18)}
.alert-home .alert-form button{flex-shrink:0;background:var(--red);color:white;border:none;border-radius:8px;padding:.85rem 1.5rem;font-size:.85rem;font-weight:600;font-family:var(--sans);cursor:pointer;transition:background .15s;white-space:nowrap}
.alert-home .alert-form button:hover{background:var(--red-deep)}
.alert-home .alert-privacy{font-size:.7rem;color:rgba(255,255,255,.35);margin-top:.75rem}
.alert-home .alert-ok{display:none;font-size:.9rem;color:#4ade80;font-weight:500;margin-top:.75rem}
@media(max-width:768px){
    .hero{min-height:auto;padding:8rem 1.5rem 3rem}.hero::before{font-size:10rem;top:5%;right:-5%}
    .stats-inner{grid-template-columns:1fr}.stat-block{padding:2rem 1.5rem}
    .stat-block:not(:last-child)::after{display:none}.stat-block:not(:last-child){border-bottom:1px solid rgba(255,255,255,0.08)}
    .how-steps{grid-template-columns:1fr}.cities-grid{grid-template-columns:1fr 1fr}
    .city-tile:nth-child(1),.city-tile:nth-child(2){grid-column:span 1;min-height:200px}
    .alert-home{padding:2rem 1.5rem}.alert-home .alert-form{flex-direction:column}
    .footer-inner{flex-direction:column;text-align:center}.footer-links{justify-content:center}
    .how-header{flex-direction:column;align-items:flex-start}.topnav-cta{display:none}
}
@media(max-width:480px){
    .cities-grid{grid-template-columns:1fr}
    .city-tile:nth-child(1),.city-tile:nth-child(2){min-height:180px}
    .search-btn{padding:0.75rem 1.25rem;font-size:0.8rem}
}
