*{box-sizing:border-box}html{background:#f4f4f2;scroll-behavior:smooth}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Helvetica Neue",Arial,sans-serif;color:#080808;background:radial-gradient(circle at 50% 0%,#fff,#f4f4f2 58%);-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button{font:inherit;color:inherit}.app{min-height:100vh;overflow:hidden}.screen{display:none}.screen.is-active{display:block}.hero{position:relative;min-height:560px;height:62vh;overflow:hidden}.hero-media{position:absolute;inset:0;background-image:url('../images/hero.jpg');background-size:cover;background-position:52% 36%;filter:saturate(.86) contrast(1.03) brightness(1.05);transform:scale(1.05);animation:kenburns 22s cubic-bezier(.2,.8,.2,1) infinite alternate}.hero:before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(255,255,255,.88),rgba(255,255,255,.45),rgba(255,255,255,.10)),linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.24) 45%,rgba(244,244,242,.98))}.hero-wash{position:absolute;left:0;right:0;bottom:-1px;z-index:2;height:42%;background:linear-gradient(180deg,rgba(244,244,242,0),rgba(244,244,242,.72) 48%,#f4f4f2)}.topbar{position:relative;z-index:3;display:flex;justify-content:space-between;padding:24px 22px 0}.brand{font-size:12px;font-weight:800;letter-spacing:.28em}.lang{min-width:52px;height:44px;border:1px solid rgba(255,255,255,.55);border-radius:999px;background:rgba(255,255,255,.74);backdrop-filter:blur(24px);font-size:12px;font-weight:800;box-shadow:0 10px 34px rgba(0,0,0,.08)}.hero-copy{position:absolute;z-index:3;left:50%;bottom:92px;width:min(560px,calc(100% - 34px));transform:translateX(-50%);text-align:center;animation:heroIn .8s cubic-bezier(.2,.8,.2,1) both}.eyebrow{display:inline-flex;align-items:center;height:31px;padding:0 14px;margin-bottom:19px;border-radius:999px;background:rgba(255,255,255,.58);backdrop-filter:blur(24px);box-shadow:0 10px 36px rgba(0,0,0,.07);color:rgba(0,0,0,.54);font-size:10px;font-weight:800;letter-spacing:.26em;text-transform:uppercase}.hero h1{margin:0;font-size:48px;line-height:.92;letter-spacing:-.07em;font-weight:850}.hero p{width:94%;margin:18px auto 0;color:rgba(0,0,0,.58);font-size:16px;line-height:1.55;font-weight:500}.actions{position:relative;z-index:5;width:calc(100% - 22px);max-width:760px;margin:-76px auto 74px}.action-card{min-height:98px;margin-bottom:14px;padding:17px;display:grid;grid-template-columns:56px 1fr 38px;gap:16px;align-items:center;border-radius:30px;background:rgba(255,255,255,.95);border:1px solid rgba(255,255,255,.72);box-shadow:0 10px 36px rgba(0,0,0,.07);backdrop-filter:blur(26px);transition:.28s cubic-bezier(.2,.8,.2,1)}.action-card:active{transform:scale(.985)}.icon-wrap{width:56px;height:56px;border-radius:19px;display:grid;place-items:center;background:radial-gradient(circle at 30% 20%,#fff,rgba(236,236,236,.88));box-shadow:inset 0 1px 0 rgba(255,255,255,.85),0 8px 22px rgba(0,0,0,.05);font-size:25px}.action-text strong{display:block;margin-bottom:6px;font-size:17px;letter-spacing:-.025em;font-weight:760}.action-text small{display:block;color:rgba(16,16,20,.58);font-size:14px;font-weight:500}.chevron{width:38px;height:38px;border-radius:999px;display:grid;place-items:center;background:rgba(255,255,255,.74);border:1px solid rgba(0,0,0,.055);box-shadow:0 8px 22px rgba(0,0,0,.045);font-size:30px}.detail{min-height:100vh;padding:22px 16px 70px;background:#f4f4f2;animation:slideIn .36s cubic-bezier(.2,.8,.2,1) both}.detail-header{max-width:760px;margin:0 auto 24px;display:flex;gap:16px;align-items:flex-start}.back-btn{width:46px;height:46px;flex:0 0 46px;border:0;border-radius:999px;background:#fff;font-size:34px;box-shadow:0 10px 30px rgba(0,0,0,.07)}.detail-header span{display:block;margin-bottom:7px;font-size:11px;font-weight:800;letter-spacing:.22em;color:rgba(0,0,0,.45)}.detail-header h1{margin:0;font-size:36px;letter-spacing:-.06em;line-height:.95}.detail-header p{margin:10px 0 0;color:rgba(0,0,0,.56);line-height:1.45;font-size:15px}.tile-grid{max-width:760px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:12px}.tile{min-height:130px;border:0;border-radius:28px;background:#fff;text-align:left;padding:17px;box-shadow:0 12px 36px rgba(0,0,0,.065);display:flex;flex-direction:column;justify-content:space-between}.tile span{width:50px;height:50px;border-radius:17px;display:grid;place-items:center;background:#f2f2f2;font-size:24px}.tile strong{font-weight:800;font-size:16px;letter-spacing:-.025em}.tile small{color:rgba(0,0,0,.52);font-size:13px;font-weight:700}.explorer,.category-screen{background:linear-gradient(180deg,#f4f4f2,#eeeeeb)}.category-strip{max-width:760px;margin:0 auto 26px;display:flex;gap:12px;overflow-x:auto;padding:4px 0 10px;scrollbar-width:none}.category-strip::-webkit-scrollbar{display:none}.chip{height:72px;min-width:112px;padding:0 16px;border:0;border-radius:26px;background:#fff;color:#111;font-size:14px;font-weight:800;box-shadow:0 8px 24px rgba(0,0,0,.055);white-space:nowrap;display:inline-flex;flex-direction:column;gap:7px;align-items:center;justify-content:center;transition:.22s cubic-bezier(.2,.8,.2,1)}.chip:active{transform:scale(.97)}.chip span{font-size:22px}.top-picks{max-width:760px;margin:0 auto 30px;background:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.78);border-radius:36px;padding:24px 18px 18px;box-shadow:0 18px 54px rgba(0,0,0,.075);backdrop-filter:blur(22px);overflow:hidden}.section-title{display:flex;align-items:flex-end;justify-content:space-between;margin:0 0 13px}.section-title h2{margin:0;font-size:13px;letter-spacing:.22em;font-weight:850;color:rgba(0,0,0,.56)}.section-title small{color:rgba(0,0,0,.5);font-weight:750}.pick-slider{display:flex;gap:15px;overflow-x:auto;scroll-snap-type:x mandatory;padding:2px 12px 12px 0;scrollbar-width:none}.pick-slider::-webkit-scrollbar{display:none}.pick-slider.nudge .pick-card:first-child{animation:nudgeCard 1.25s .8s cubic-bezier(.2,.8,.2,1) 2}.pick-card{position:relative;display:flex;flex-direction:column;flex:0 0 82%;max-width:385px;scroll-snap-align:start;background:#fff;border-radius:32px;overflow:hidden;box-shadow:0 15px 46px rgba(0,0,0,.10);height:430px;border:0;text-align:left;padding:0;cursor:pointer}.pick-card-img-wrap{position:relative;height:180px;width:100%;flex:0 0 180px;overflow:hidden;background:#eee;border-radius:0}.pick-card-img-wrap img{width:100%;height:100%;display:block;object-fit:cover;object-position:center;margin:0;padding:0;border:0}.heart-badge{position:absolute;top:14px;right:14px;z-index:2;color:#ff3b30;background:transparent;display:block;font-size:28px;line-height:1;text-shadow:0 4px 16px rgba(0,0,0,.22)}.pick-body{padding:17px;display:flex;flex-direction:column;flex:1;min-height:0}.pick-body h3{margin:0 0 5px;font-size:22px;letter-spacing:-.045em}.pick-body .type{margin:0 0 10px;color:rgba(0,0,0,.56);font-size:13px;font-weight:850}.pick-body p{margin:0 0 14px;color:rgba(0,0,0,.60);line-height:1.43;font-size:14px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.pick-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto;padding-top:8px}.pick-meta span{height:28px;padding:0 10px;border-radius:999px;background:#f2f2f2;display:inline-flex;align-items:center;font-size:12px;font-weight:800;color:rgba(0,0,0,.60)}.map-card{max-width:760px;margin:8px auto 18px;border-radius:36px;overflow:hidden;background:rgba(255,255,255,.84);border:1px solid rgba(255,255,255,.78);box-shadow:0 18px 54px rgba(0,0,0,.085);backdrop-filter:blur(22px)}.map-visual{height:150px;position:relative;background:linear-gradient(135deg,#f0ece4,#dcd6ca);overflow:hidden}.map-visual:before{content:'';position:absolute;inset:-40px;background:repeating-linear-gradient(35deg,rgba(255,255,255,.28) 0 3px,transparent 3px 38px),repeating-linear-gradient(125deg,rgba(255,255,255,.22) 0 4px,transparent 4px 46px);opacity:.78}.map-visual span{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:58px;height:58px;border-radius:999px;background:#fff;display:grid;place-items:center;font-size:27px;box-shadow:0 16px 44px rgba(0,0,0,.16)}.map-content{padding:20px}.map-content h2{margin:0 0 8px;font-size:24px;letter-spacing:-.04em}.map-content p{margin:0 0 18px;color:rgba(0,0,0,.58);line-height:1.55}.map-content a,.panel-link,.top-cta{display:inline-flex;height:42px;align-items:center;padding:0 14px;border-radius:999px;background:#111;color:#fff;font-weight:800;font-size:14px}.category-list{max-width:760px;margin:0 auto;display:grid;gap:13px}.category-row{background:#fff;text-align:left;border-radius:28px;padding:14px;box-shadow:0 10px 32px rgba(0,0,0,.06);display:grid;grid-template-columns:86px 1fr 28px;gap:14px;align-items:center}.category-row-img{height:86px;border-radius:22px;background-size:cover;background-position:center}.category-row h3{margin:0 0 5px;font-size:18px;letter-spacing:-.035em}.category-row p{margin:0 0 8px;color:rgba(0,0,0,.58);font-size:13.5px;line-height:1.35}.category-row small{font-weight:800;color:rgba(0,0,0,.52)}.category-row b{font-size:22px;font-weight:700}.top-detail-screen{min-height:100vh;background:#fff;animation:slideIn .36s cubic-bezier(.2,.8,.2,1) both}.place-back{position:fixed;top:20px;left:18px;z-index:5;width:46px;height:46px;border:0;border-radius:999px;background:rgba(255,255,255,.82);backdrop-filter:blur(18px);font-size:34px;box-shadow:0 10px 30px rgba(0,0,0,.12)}.top-hero{height:38vh;min-height:300px;position:relative;overflow:hidden;background:#eee}.top-hero img{width:100%;height:100%;display:block;object-fit:cover;object-position:center}.top-hero:after{content:'';position:absolute;inset:45% 0 0;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.76))}.top-content{max-width:760px;margin:-44px auto 0;position:relative;z-index:2;background:#fff;border-radius:34px 34px 0 0;padding:26px 18px 54px}.top-content h1{margin:0 0 7px;font-size:34px;letter-spacing:-.06em}.top-content .type{margin:0 0 16px;font-weight:850;color:rgba(0,0,0,.54)}.top-content p{color:rgba(0,0,0,.62);line-height:1.55}.info-chip-row{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0}.info-chip-row span{height:32px;padding:0 11px;border-radius:999px;background:#f2f2f2;display:inline-flex;align-items:center;font-size:13px;font-weight:850;color:rgba(0,0,0,.65)}.top-block{margin-top:16px;border-radius:24px;background:#f4f4f2;padding:17px}.top-block h3{margin:0 0 10px;font-size:16px}.top-block ul{margin:0;padding-left:18px;color:rgba(0,0,0,.65);line-height:1.6}.assist-stack{max-width:760px;margin:0 auto 16px;display:grid;gap:14px}.assist-card{width:100%;border:0;border-radius:30px;background:#fff;box-shadow:0 12px 36px rgba(0,0,0,.065);padding:18px;display:grid;grid-template-columns:54px 1fr 34px;gap:16px;align-items:center;text-align:left}.assist-card span{width:54px;height:54px;border-radius:18px;background:#f2f2f2;display:grid;place-items:center;font-size:24px}.assist-card strong{display:block;font-size:17px;margin-bottom:5px;letter-spacing:-.025em}.assist-card small{color:rgba(0,0,0,.55);font-weight:650}.assist-card.primary{background:#111;color:#fff}.assist-card.primary span{background:rgba(255,255,255,.14)}.assist-card.primary small{color:rgba(255,255,255,.65)}.assist-card.danger{background:#fff5f5;color:#7f1414}.assist-card.danger span{background:#ffe3e3}.panel{position:fixed;inset:0;z-index:20;background:rgba(0,0,0,.22);display:none;align-items:flex-end}.panel.is-open{display:flex}.panel-card{width:100%;max-width:760px;margin:0 auto;background:#fff;border-radius:34px 34px 0 0;padding:22px 18px 34px;box-shadow:0 -22px 70px rgba(0,0,0,.18);animation:sheetIn .32s cubic-bezier(.2,.8,.2,1) both}.panel-close{height:42px;padding:0 16px;border:0;border-radius:999px;background:#f2f2f2;font-weight:800;float:right}.panel h2{clear:both;margin:42px 0 8px;font-size:30px;letter-spacing:-.05em}.panel p{color:rgba(0,0,0,.58);line-height:1.55}.info-block,details{margin-top:12px;border-radius:22px;background:#f4f4f2;padding:16px}.copy-row{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-top:10px}.copy-row code{font-size:16px;font-weight:800}.copy-row button{border:0;border-radius:999px;background:#111;color:#fff;padding:10px 14px;font-weight:800}.checklist,.faq-list,.issue-grid,.emergency-list{display:grid;gap:10px;margin-top:16px}.checklist label,.issue-grid button,.emergency-list a{display:flex;gap:10px;align-items:center;background:#f4f4f2;border:0;border-radius:18px;padding:14px;font-weight:800}.rule-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}.rule-grid div{background:#f4f4f2;border-radius:18px;padding:14px;font-weight:800}summary{font-weight:850;cursor:pointer}@keyframes kenburns{from{transform:scale(1.045)}to{transform:scale(1.12)}}@keyframes heroIn{from{opacity:0;transform:translate(-50%,18px);filter:blur(6px)}to{opacity:1;transform:translate(-50%,0);filter:blur(0)}}@keyframes slideIn{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:translateX(0)}}@keyframes sheetIn{from{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes nudgeCard{0%,100%{transform:translateX(0)}45%{transform:translateX(-22px)}70%{transform:translateX(6px)}}@media(min-width:761px){.hero{min-height:580px;height:58vh}.topbar{padding:28px 34px 0}.hero h1{font-size:clamp(54px,7vw,92px)}.hero p{font-size:20px}.actions{width:min(760px,calc(100% - 32px))}.detail-header h1{font-size:46px}.tile{min-height:150px}.pick-card{flex:0 0 360px;max-width:360px;height:430px}.top-hero{height:460px}}
/* TEKNIMO app navigation + V3 simplification */
:root{
  --bg:#f7f7f5;
  --card:#fff;
  --text:#111;
  --muted:rgba(0,0,0,.56);
  --border:rgba(0,0,0,.055);
  --shadow:0 8px 24px rgba(0,0,0,.05);
  --radius:24px;
}
body{background:var(--bg);padding-bottom:calc(86px + env(safe-area-inset-bottom));}
.app{padding-bottom:calc(86px + env(safe-area-inset-bottom));}
.hero h1{font-size:clamp(46px,12vw,78px);line-height:.9;letter-spacing:-.075em;}
.hero p{max-width:460px;}
.actions{margin-bottom:calc(96px + env(safe-area-inset-bottom));}
.action-card{border-radius:24px;box-shadow:var(--shadow);border:1px solid var(--border);}
.detail{padding-bottom:calc(108px + env(safe-area-inset-bottom));background:var(--bg);}
.detail-header{padding-top:4px;}
.back-btn{display:none;}
.detail-header span{letter-spacing:.18em;}
.tile,.assist-card,.category-row{border:1px solid var(--border);box-shadow:var(--shadow);}
.service-tile{grid-column:span 2;min-height:112px;}
.category-strip{padding-left:1px;}
.chip{height:64px;min-width:104px;border-radius:22px;border:1px solid var(--border);box-shadow:var(--shadow);}
.chip span{font-size:20px;}
.top-picks{background:#fcfcfc;border:1px solid var(--border);border-radius:28px;padding:18px 14px 14px;box-shadow:var(--shadow);backdrop-filter:none;}
.section-title{align-items:flex-start;margin-bottom:14px;}
.section-title h2{font-size:18px;letter-spacing:-.035em;text-transform:none;color:#111;}
.section-title small{display:block;margin-top:5px;font-size:13px;color:var(--muted);font-weight:650;line-height:1.35;}
.pick-slider{gap:14px;padding-bottom:4px;}
.pick-card{flex-basis:78%;height:375px;border-radius:24px;box-shadow:var(--shadow);border:1px solid var(--border);}
.pick-card-img-wrap{height:168px;flex-basis:168px;}
.heart-badge{font-size:24px;top:12px;right:12px;text-shadow:0 3px 12px rgba(0,0,0,.18);}
.pick-body{padding:15px;}
.pick-body h3{font-size:20px;margin-bottom:4px;}
.pick-body .type{font-size:12px;margin-bottom:8px;}
.pick-body p{-webkit-line-clamp:2;font-size:13.5px;line-height:1.36;margin-bottom:10px;}
.pick-meta span{height:25px;padding:0 9px;font-size:11.5px;background:#f5f5f4;}
.map-card{border-radius:28px;border:1px solid var(--border);box-shadow:var(--shadow);backdrop-filter:none;background:#fff;}
.map-visual{height:128px;background:linear-gradient(135deg,#f7f4ec,#e4ded2);}
.map-content{padding:18px;}
.map-content h2{font-size:22px;}
.map-content p{font-size:14px;line-height:1.48;}
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:30;height:calc(76px + env(safe-area-inset-bottom));padding:8px 16px calc(8px + env(safe-area-inset-bottom));display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:rgba(255,255,255,.96);border-top:1px solid rgba(0,0,0,.07);box-shadow:0 -10px 30px rgba(0,0,0,.055);backdrop-filter:blur(18px);}
.tab{border:0;background:transparent;border-radius:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:rgba(0,0,0,.42);font-weight:750;transition:.2s cubic-bezier(.2,.8,.2,1);}
.tab span{font-size:21px;line-height:1;}
.tab small{font-size:11px;}
.tab.is-active{color:#111;background:#f4f4f2;}
.tab:active{transform:scale(.96);}
.request-form{display:grid;gap:12px;margin-top:18px;clear:both;}
.request-form label{display:grid;gap:7px;font-weight:800;font-size:13px;color:rgba(0,0,0,.68);}
.request-form input,.request-form textarea,.request-form select{width:100%;border:1px solid rgba(0,0,0,.08);border-radius:16px;background:#f7f7f5;padding:13px 14px;font:inherit;font-size:15px;outline:none;}
.request-form input:focus,.request-form textarea:focus,.request-form select:focus{border-color:rgba(0,0,0,.22);background:#fff;}
.request-form button[type="submit"]{height:48px;border:0;border-radius:18px;background:#111;color:#fff;font-weight:850;margin-top:4px;}
.form-note{color:rgba(0,0,0,.48);line-height:1.35;}
.form-success,.form-error{border-radius:16px;padding:12px 14px;font-weight:750;font-size:14px;}
.form-success{background:#eef8f1;color:#145c2e;}
.form-error{background:#fff0f0;color:#8a1f1f;}
.favorite-note h3{color:#111;}
@media(max-width:380px){.pick-card{flex-basis:84%;height:362px}.pick-card-img-wrap{height:156px;flex-basis:156px}.tile-grid{gap:10px}.tile{min-height:120px;padding:15px}.tabbar{padding-left:10px;padding-right:10px}.tab small{font-size:10px}}
@media(min-width:761px){.tabbar{left:50%;transform:translateX(-50%);max-width:760px;border-radius:28px 28px 0 0}.pick-card{flex:0 0 300px;height:370px}.pick-card-img-wrap{height:165px;flex-basis:165px}.service-tile{grid-column:auto}}

/* V4 — Mobile Safari/PWA + premium Lucide icons */
:root{
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --tabbar-height: calc(92px + var(--safe-bottom));
  --icon-stroke: 1.75;
}
.app{min-height:100dvh;padding-bottom:var(--tabbar-height);}
.detail{min-height:100dvh;padding-bottom:calc(var(--tabbar-height) + 24px);}
.lucide-icon{width:1em;height:1em;display:block;stroke:currentColor;stroke-width:var(--icon-stroke);stroke-linecap:round;stroke-linejoin:round;fill:none;}
.icon-wrap .lucide-icon{width:26px;height:26px;}
.tile span .lucide-icon,.assist-card span .lucide-icon{width:24px;height:24px;}
.chip span{width:40px;height:40px;border-radius:999px;background:#f3f3f1;display:grid;place-items:center;font-size:20px;}
.chip span .lucide-icon{width:20px;height:20px;}
.map-visual span .lucide-icon{width:28px;height:28px;}
.tabbar{
  height:var(--tabbar-height);
  padding:12px 16px calc(10px + var(--safe-bottom));
  background:#fff;
  box-shadow:0 -8px 24px rgba(0,0,0,.045);
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.tab{position:relative;gap:7px;border-radius:18px;color:#8e8e93;font-weight:650;}
.tab::before{content:'';position:absolute;top:0;left:50%;width:20px;height:2px;border-radius:999px;background:#111;transform:translateX(-50%) scaleX(0);opacity:0;transition:transform .22s ease,opacity .22s ease;}
.tab span{font-size:26px;line-height:1;display:grid;place-items:center;transition:transform .22s ease,opacity .22s ease;}
.tab span .lucide-icon{width:26px;height:26px;}
.tab small{font-size:13px;line-height:1;font-weight:650;}
.tab.is-active{color:#111;background:transparent;}
.tab.is-active::before{opacity:1;transform:translateX(-50%) scaleX(1);}
.tab.is-active span{transform:scale(1.08);}
@supports not (height:100dvh){.app,.detail{min-height:100vh;}}
@media(max-width:380px){.tabbar{padding-left:10px;padding-right:10px}.tab small{font-size:12px}.tab span .lucide-icon{width:24px;height:24px}}

/* V4.1 Sprint 1 — Footer définitif */
:root{
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --tabbar-height: calc(96px + var(--safe-bottom));
}
html,body{min-height:100%;}
body{
  padding-bottom:var(--tabbar-height);
  overscroll-behavior-y:none;
}
.app{
  min-height:100dvh;
  padding-bottom:var(--tabbar-height);
}
.screen.detail,
.detail,
.top-detail-screen{
  padding-bottom:calc(var(--tabbar-height) + 28px);
}
.actions{
  margin-bottom:calc(var(--tabbar-height) + 20px);
}
.tabbar{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:50;
  height:var(--tabbar-height);
  padding:14px 18px calc(12px + var(--safe-bottom));
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:4px;
  background:#fff;
  border-top:1px solid rgba(0,0,0,.055);
  box-shadow:0 -6px 22px rgba(0,0,0,.04);
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.tab{
  position:relative;
  min-width:0;
  min-height:66px;
  padding:8px 0 0;
  border:0;
  border-radius:18px;
  background:transparent;
  color:#8e8e93;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:650;
  transition:color .22s ease, transform .22s ease, opacity .22s ease;
  -webkit-tap-highlight-color:transparent;
}
.tab::before{
  content:'';
  position:absolute;
  top:2px;
  left:50%;
  width:20px;
  height:2px;
  border-radius:999px;
  background:#111;
  opacity:0;
  transform:translateX(-50%) scaleX(.45);
  transition:opacity .22s ease, transform .22s cubic-bezier(.2,.8,.2,1);
}
.tab span{
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  line-height:1;
  transition:transform .22s cubic-bezier(.2,.8,.2,1), opacity .22s ease;
}
.tab span .lucide-icon{
  width:26px;
  height:26px;
  stroke-width:1.75;
}
.tab small{
  font-size:13px;
  line-height:1;
  letter-spacing:-.01em;
  font-weight:650;
  transition:font-weight .22s ease, opacity .22s ease;
}
.tab.is-active{
  color:#111;
  background:transparent;
}
.tab.is-active::before{
  opacity:1;
  transform:translateX(-50%) scaleX(1);
}
.tab.is-active span{
  transform:scale(1.08);
}
.tab.is-active small{
  font-weight:760;
}
.tab:active{
  transform:scale(.965);
}
@media(max-width:380px){
  :root{--tabbar-height:calc(92px + var(--safe-bottom));}
  .tabbar{padding-left:10px;padding-right:10px;gap:0;}
  .tab span .lucide-icon{width:24px;height:24px;}
  .tab small{font-size:12px;}
}
@media(min-width:761px){
  .tabbar{
    left:50%;
    right:auto;
    width:min(760px,100%);
    transform:translateX(-50%);
    border-radius:28px 28px 0 0;
  }
}
@supports not (min-height:100dvh){
  .app{min-height:100vh;}
}


/* Sprint2 Home cards */
.home-sections,.quick-links,.home-grid{display:grid;grid-template-columns:1fr;gap:18px;padding:28px 20px 120px}
.home-card,.feature-card{
background:#fff;border:1px solid rgba(0,0,0,.05);border-radius:24px;
padding:22px;box-shadow:0 8px 24px rgba(0,0,0,.05);
transition:transform .22s ease,box-shadow .22s ease}
.home-card:active,.feature-card:active{transform:scale(.98)}
.home-card h3,.feature-card h3{font-size:20px;margin:12px 0 6px}
.home-card p,.feature-card p{font-size:14px;color:#666;line-height:1.5;margin:0}
.hero-copy h1{font-size:42px;line-height:1.02;letter-spacing:-.04em}
.hero-copy .subtitle{font-size:17px;line-height:1.55;color:#555;max-width:340px;margin:16px auto 0}

/* V4.1 Sprint 3 — corrections demandées */
.tile-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.service-tile{grid-column:1 / -1;min-height:112px;}
.panel-note{font-size:13px;color:rgba(0,0,0,.52);margin-top:14px;}
.checkout-list label{align-items:flex-start;line-height:1.35;}
.checkout-list input{margin-top:2px;accent-color:#111;}

/* Explorer — catégories plus sobres, sans rond autour des icônes */
.category-strip{
  max-width:760px;
  margin:0 auto 24px;
  padding:4px 2px 12px;
  gap:10px;
  -webkit-overflow-scrolling:touch;
}
.chip{
  min-width:auto;
  height:44px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.055);
  background:#fff;
  box-shadow:0 6px 18px rgba(0,0,0,.045);
  flex-direction:row;
  gap:8px;
  font-size:13px;
  letter-spacing:-.01em;
}
.chip span{
  width:auto!important;
  height:auto!important;
  border-radius:0!important;
  background:transparent!important;
  display:grid;
  place-items:center;
}
.chip span .lucide-icon{width:18px;height:18px;}
.chip:active{transform:scale(.975);}

/* Google Maps card — prêt pour un vrai screenshot */
.map-card{border-radius:30px;background:#fff;border:1px solid rgba(0,0,0,.055);box-shadow:0 10px 30px rgba(0,0,0,.055);overflow:hidden;}
.map-visual.map-preview{height:172px;background:#e9e4d8;}
.map-visual.map-preview img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.92) contrast(1.02);}
.map-visual.map-preview:before{display:none;}
.map-visual.map-preview span{right:14px;left:auto;top:auto;bottom:14px;transform:none;width:48px;height:48px;background:#fff;box-shadow:0 10px 28px rgba(0,0,0,.16);}
.map-content a{height:48px;border-radius:18px;padding:0 18px;}

/* Navigation retour plus explicite */
.back-label{width:auto;min-width:104px;padding:0 14px;font-size:15px;font-weight:850;border-radius:999px;}
.place-back-label{width:auto;min-width:112px;padding:0 14px;font-size:15px;font-weight:850;border-radius:999px;}

/* Category rows are buttons now */
.category-row{width:100%;border:0;color:inherit;font:inherit;cursor:pointer;}
.category-row:active{transform:scale(.992);}

/* Fiche adresse — CTA Google Maps repositionné */
.info-chip-row span{height:30px;background:#f5f5f4;}
.try-capsules{display:flex;gap:8px;flex-wrap:wrap;}
.try-capsules span{height:30px;padding:0 12px;border-radius:999px;background:#fff;border:1px solid rgba(0,0,0,.06);display:inline-flex;align-items:center;font-size:13px;font-weight:800;color:rgba(0,0,0,.68);}
.top-cta-full{display:flex!important;width:100%;height:52px!important;justify-content:center;border-radius:20px!important;margin-top:24px;margin-bottom:32px;font-size:15px!important;}
.top-block{background:#f7f7f5;border:1px solid rgba(0,0,0,.045);}
.favorite-note{background:#fff7f7;}

@media(max-width:380px){.chip{height:42px;padding:0 13px;font-size:12.5px}.map-visual.map-preview{height:150px}.back-label,.place-back-label{min-width:96px;font-size:14px}}

/* Fix Sprint 3 — Category Lucide icons clipping */
.chip {
  gap: 10px;
  padding: 0 18px;
  overflow: visible;
}

.chip span {
  overflow: visible;
  flex: 0 0 auto;
}

.chip span .lucide-icon {
  width: 20px;
  height: 20px;
  overflow: visible;
}

@media(max-width:380px){
  .chip {
    gap: 9px;
    padding: 0 15px;
  }

  .chip span .lucide-icon {
    width: 19px;
    height: 19px;
  }
}

/* V4.1 Icon system fix — prevents Lucide icons from being clipped */
svg,
.lucide-icon{
  overflow:visible;
}

.lucide-icon{
  flex-shrink:0;
  stroke-width:1.75;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.icon-wrap,
.tile span,
.assist-card span,
.chip span,
.tab span,
.map-visual span{
  overflow:visible;
}

.icon-wrap .lucide-icon{
  width:26px;
  height:26px;
}

.tile span .lucide-icon,
.assist-card span .lucide-icon{
  width:24px;
  height:24px;
}

.chip span .lucide-icon{
  width:20px;
  height:20px;
  overflow:visible;
}

.chip{
  gap:10px;
  padding:0 18px;
}

.tab span .lucide-icon{
  width:26px;
  height:26px;
}


/* V4.1 HARD FIX — Lucide internal viewBox padding + icon alignment */
svg, .lucide-icon{ overflow: visible !important; }
.lucide-icon{ flex-shrink:0; display:block; stroke-width:1.75; stroke-linecap:round; stroke-linejoin:round; fill:none; }
.icon-wrap,.tile span,.assist-card span,.chip span,.tab span,.map-visual span{ overflow:visible !important; }
.chip{ overflow:visible !important; gap:10px; padding:0 18px; }
.chip span{ overflow:visible !important; flex:0 0 auto; }
.chip span .lucide-icon{ width:20px !important; height:20px !important; }
.tile span .lucide-icon,.assist-card span .lucide-icon{ width:24px !important; height:24px !important; }
.icon-wrap .lucide-icon{ width:26px !important; height:26px !important; }
.tab span .lucide-icon{ width:26px !important; height:26px !important; }


/* V4.1 ICON FINAL FIX — no viewBox hacks, centered handmade icons */
.lucide-icon{ overflow:visible !important; vector-effect:non-scaling-stroke; }
.chip span .lucide-icon{ width:22px !important; height:22px !important; }
.tile span .lucide-icon{ width:28px !important; height:28px !important; }
.assist-card span .lucide-icon{ width:26px !important; height:26px !important; }
.icon-wrap .lucide-icon{ width:28px !important; height:28px !important; }
.chip{ gap:12px !important; padding:0 20px !important; }
.chip span,.tile span,.assist-card span,.icon-wrap{ display:grid !important; place-items:center !important; overflow:visible !important; }


/* V1 final — Accueil FAQ, Séjour, Aide, formulaires */
.home-faq{max-width:760px;margin:0 auto calc(var(--tabbar-height) + 32px);padding:0 18px 24px;}
.home-faq-title{margin-bottom:12px;}
.home-faq-title span{display:block;margin-bottom:6px;font-size:11px;font-weight:850;letter-spacing:.18em;color:rgba(0,0,0,.44);}
.home-faq-title h2{margin:0;font-size:24px;letter-spacing:-.04em;}
.faq-accordion{display:grid;gap:10px;}
.faq-item{border:1px solid rgba(0,0,0,.055);border-radius:22px;background:#fff;box-shadow:0 8px 24px rgba(0,0,0,.045);overflow:hidden;}
.faq-question{width:100%;min-height:56px;border:0;background:transparent;padding:0 16px;display:flex;align-items:center;justify-content:space-between;text-align:left;font-weight:850;font-size:15px;letter-spacing:-.015em;}
.faq-question span{font-size:20px;color:rgba(0,0,0,.42);transition:transform .22s ease;}
.faq-answer{display:none;padding:0 16px 16px;color:rgba(0,0,0,.58);font-size:14px;line-height:1.5;}
.faq-item.is-open .faq-answer{display:block;}
.faq-item.is-open .faq-question span{transform:rotate(45deg);}

.panel{align-items:flex-end;background:rgba(0,0,0,.30);}
.panel-card{max-height:85dvh;overflow-y:auto;padding:18px 18px calc(24px + env(safe-area-inset-bottom));scrollbar-width:none;}
.panel-card::-webkit-scrollbar{display:none;}
.panel-close{float:none;margin-left:auto;display:flex;align-items:center;height:38px;font-size:14px;}
.panel h2{margin:18px 0 8px;font-size:28px;}
.request-form h3{margin:6px 0 0;font-size:15px;letter-spacing:-.02em;}
.request-form input,.request-form textarea,.request-form select{min-height:48px;}
.request-form button[type="submit"]{position:sticky;bottom:0;height:52px;border-radius:18px;box-shadow:0 -8px 24px rgba(255,255,255,.92);z-index:2;}
.pro-fields{display:none;gap:12px;}
.pro-fields.is-visible{display:grid;}

.keybox-card{margin-top:16px;border-radius:24px;background:#fff;border:1px solid rgba(0,0,0,.055);box-shadow:0 8px 24px rgba(0,0,0,.045);overflow:hidden;}
.keybox-card img{width:100%;display:block;object-fit:cover;}
.keybox-tags{display:flex;gap:8px;flex-wrap:wrap;padding:12px;}
.keybox-tags span{height:30px;padding:0 12px;border-radius:999px;background:#f4f4f2;display:inline-flex;align-items:center;font-size:12px;font-weight:850;color:rgba(0,0,0,.64);}
.step-list{margin:0;padding-left:20px;color:rgba(0,0,0,.68);line-height:1.58;font-size:14px;}
.step-list li{margin:6px 0;}

.service-tile{grid-column:auto;}
@media(max-width:420px){.home-faq{padding-left:14px;padding-right:14px}.panel-card{border-radius:30px 30px 0 0}.tile-grid{grid-template-columns:1fr 1fr}.tile{min-height:124px}.rule-grid{grid-template-columns:1fr}}


/* V1.0.1 — Safari mobile UX patch */
html,
body{
  touch-action:manipulation;
  -webkit-text-size-adjust:100%;
}
body.sheet-open{
  overflow:hidden;
}
:root{
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --tabbar-height:86px;
  --floating-tabbar-bottom:calc(var(--safe-bottom) + 14px);
}
body{
  padding-bottom:calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 10px) !important;
}
.app{
  padding-bottom:calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 10px) !important;
  overflow-x:hidden;
}
.detail,
.screen.detail,
.top-detail-screen{
  padding:18px 16px calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 28px) !important;
}
.detail-header{
  margin-bottom:16px !important;
  gap:12px !important;
}
.detail-header h1{
  font-size:clamp(38px,10vw,48px) !important;
  line-height:.92 !important;
}
.detail-header p{
  margin-top:8px !important;
  font-size:15px !important;
  line-height:1.35 !important;
}
.tile-grid{
  gap:10px !important;
}
.tile{
  min-height:106px !important;
  padding:14px !important;
  border-radius:24px !important;
}
.tile span{
  width:44px !important;
  height:44px !important;
  border-radius:15px !important;
}
.tile span .lucide-icon{
  width:22px !important;
  height:22px !important;
}
.tile strong{
  font-size:15px !important;
  line-height:1.05 !important;
}
.tile small{
  font-size:12px !important;
  line-height:1.15 !important;
}
.tabbar{
  left:14px !important;
  right:14px !important;
  bottom:var(--floating-tabbar-bottom) !important;
  height:72px !important;
  padding:9px 12px !important;
  border-radius:28px !important;
  border:1px solid rgba(0,0,0,.06) !important;
  background:rgba(255,255,255,.92) !important;
  box-shadow:0 16px 42px rgba(0,0,0,.14) !important;
  backdrop-filter:blur(22px) saturate(1.2) !important;
  -webkit-backdrop-filter:blur(22px) saturate(1.2) !important;
}
.tab{
  min-height:52px !important;
  padding:6px 0 0 !important;
  gap:5px !important;
}
.tab::before{
  top:0 !important;
  width:18px !important;
  height:2px !important;
}
.tab span{
  width:24px !important;
  height:24px !important;
}
.tab span .lucide-icon{
  width:22px !important;
  height:22px !important;
}
.tab small{
  font-size:11.5px !important;
  font-weight:720 !important;
}
.panel{
  align-items:flex-end !important;
  background:rgba(0,0,0,.34) !important;
  z-index:90 !important;
  overscroll-behavior:contain;
}
.panel-card{
  position:relative;
  max-height:min(78dvh,720px) !important;
  overflow-y:auto !important;
  -webkit-overflow-scrolling:touch !important;
  padding:18px 18px calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 34px) !important;
  border-radius:32px 32px 0 0 !important;
  overscroll-behavior:contain;
}
.panel-close{
  position:sticky !important;
  top:0 !important;
  z-index:5 !important;
  margin-left:auto !important;
  float:none !important;
  height:38px !important;
  padding:0 16px !important;
  font-size:14px !important;
  background:#f4f4f2 !important;
}
.panel h2{
  margin:22px 0 10px !important;
  font-size:clamp(30px,8vw,42px) !important;
  line-height:.95 !important;
}
.panel p{
  font-size:16px !important;
  line-height:1.48 !important;
}
.info-block{
  padding:14px !important;
  border-radius:20px !important;
}
.wifi-info{
  display:grid !important;
  gap:8px !important;
}
.wifi-info small{
  font-size:13px;
  color:rgba(0,0,0,.58);
  font-weight:750;
}
.wifi-info code{
  font-size:18px !important;
  font-weight:850 !important;
  word-break:break-word;
}
.wifi-password .panel-main-cta{
  width:100% !important;
  margin-top:8px !important;
}
.copy-row{
  display:grid !important;
  grid-template-columns:1fr !important;
  align-items:start !important;
  gap:12px !important;
}
.copy-row button,
.panel-main-cta,
.request-form button[type="submit"]{
  width:100% !important;
  min-height:52px !important;
  border-radius:18px !important;
  justify-content:center !important;
}
.request-form{
  gap:12px !important;
}
.request-form input,
.request-form textarea,
.request-form select{
  min-height:48px !important;
  font-size:16px !important;
}
.request-form button[type="submit"]{
  position:sticky !important;
  bottom:calc(var(--floating-tabbar-bottom) + 8px) !important;
  z-index:4 !important;
  box-shadow:0 -10px 30px rgba(255,255,255,.96) !important;
}
.whatsapp-submit{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
}
.wa-logo{
  width:22px;
  height:22px;
  color:#25D366;
  display:inline-grid;
  place-items:center;
  flex:0 0 auto;
}
.wa-logo svg{
  width:22px;
  height:22px;
  display:block;
}
.checkout-list{
  gap:9px !important;
}
.checkout-list label{
  min-height:54px !important;
  padding:12px !important;
  border-radius:18px !important;
  font-size:15px !important;
  line-height:1.28 !important;
}
.checkout-list input{
  flex:0 0 auto;
  width:18px;
  height:18px;
}
@media(max-width:380px){
  :root{--tabbar-height:80px;--floating-tabbar-bottom:calc(var(--safe-bottom) + 10px);}
  .detail,.screen.detail{padding-left:14px !important;padding-right:14px !important;}
  .tile{min-height:98px !important;padding:12px !important;}
  .tile span{width:40px !important;height:40px !important;}
  .tile strong{font-size:14px !important;}
  .tile small{font-size:11.5px !important;}
  .tabbar{left:10px !important;right:10px !important;height:68px !important;border-radius:26px !important;}
  .tab small{font-size:11px !important;}
  .panel-card{max-height:80dvh !important;padding-left:16px !important;padding-right:16px !important;}
}
@media(min-width:761px){
  .tabbar{
    left:50% !important;
    right:auto !important;
    width:min(720px,calc(100% - 28px)) !important;
    transform:translateX(-50%) !important;
  }
}


/* V1.0.2 — final mobile UX patch for GitHub/Cloudflare */
:root{
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --tabbar-height:72px;
  --floating-tabbar-bottom:calc(var(--safe-bottom) + 14px);
}
html,
body{
  touch-action:manipulation;
  -webkit-text-size-adjust:100%;
  overscroll-behavior-y:none;
}
body{
  padding-bottom:calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 18px) !important;
}
body.sheet-open{
  overflow:hidden !important;
}
.app{
  min-height:100dvh !important;
  padding-bottom:calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 18px) !important;
  overflow-x:hidden !important;
}
.detail,
.screen.detail,
.top-detail-screen{
  padding:18px 16px calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 30px) !important;
}
.actions{
  margin-bottom:28px !important;
}
.home-faq{
  margin-bottom:calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 26px) !important;
}
.detail-header{
  margin-bottom:14px !important;
  gap:12px !important;
}
.detail-header h1{
  font-size:clamp(36px,9.5vw,46px) !important;
  line-height:.94 !important;
}
.detail-header p{
  margin-top:8px !important;
  font-size:14.5px !important;
  line-height:1.34 !important;
}
.tile-grid{
  gap:10px !important;
}
.tile{
  min-height:102px !important;
  padding:13px !important;
  border-radius:23px !important;
}
.tile span{
  width:42px !important;
  height:42px !important;
  border-radius:15px !important;
}
.tile span .lucide-icon{
  width:21px !important;
  height:21px !important;
}
.tile strong{
  font-size:15px !important;
  line-height:1.05 !important;
}
.tile small{
  font-size:11.7px !important;
  line-height:1.15 !important;
}
.tabbar{
  left:14px !important;
  right:14px !important;
  bottom:var(--floating-tabbar-bottom) !important;
  height:var(--tabbar-height) !important;
  padding:9px 12px !important;
  border-radius:28px !important;
  border:1px solid rgba(0,0,0,.06) !important;
  background:rgba(255,255,255,.92) !important;
  box-shadow:0 16px 42px rgba(0,0,0,.14) !important;
  backdrop-filter:blur(22px) saturate(1.2) !important;
  -webkit-backdrop-filter:blur(22px) saturate(1.2) !important;
  z-index:50 !important;
}
.tab{
  min-height:52px !important;
  padding:6px 0 0 !important;
  gap:5px !important;
}
.tab::before{
  top:0 !important;
  width:16px !important;
  height:2px !important;
}
.tab span{
  width:24px !important;
  height:24px !important;
}
.tab span .lucide-icon{
  width:22px !important;
  height:22px !important;
}
.tab small{
  font-size:11.5px !important;
  font-weight:720 !important;
}
.panel{
  z-index:90 !important;
  align-items:flex-end !important;
  background:rgba(0,0,0,.34) !important;
  overscroll-behavior:contain !important;
}
.panel-card{
  position:relative !important;
  width:100% !important;
  max-height:min(78dvh,720px) !important;
  overflow-y:auto !important;
  -webkit-overflow-scrolling:touch !important;
  overscroll-behavior:contain !important;
  padding:18px 18px 24px !important;
  border-radius:32px 32px 0 0 !important;
  scrollbar-width:none !important;
}
.panel-card::-webkit-scrollbar{display:none !important;}
.panel-close{
  position:sticky !important;
  top:0 !important;
  z-index:6 !important;
  margin-left:auto !important;
  float:none !important;
  height:38px !important;
  padding:0 16px !important;
  font-size:14px !important;
  background:#f4f4f2 !important;
}
.panel h2{
  margin:20px 0 10px !important;
  font-size:clamp(30px,8vw,42px) !important;
  line-height:.95 !important;
}
.panel p{
  font-size:15.5px !important;
  line-height:1.48 !important;
}
.info-block{
  padding:14px !important;
  border-radius:20px !important;
}
.copy-row{
  display:grid !important;
  grid-template-columns:1fr !important;
  align-items:start !important;
  gap:12px !important;
}
.wifi-info{
  display:grid !important;
  gap:8px !important;
}
.wifi-info small{
  font-size:13px !important;
  color:rgba(0,0,0,.58) !important;
  font-weight:750 !important;
}
.wifi-info code{
  font-size:18px !important;
  font-weight:850 !important;
  word-break:break-word !important;
}
.copy-row button,
.panel-main-cta,
.request-form button[type="submit"]{
  width:100% !important;
  min-height:52px !important;
  border-radius:18px !important;
  justify-content:center !important;
}
.wifi-password .panel-main-cta{
  margin-top:8px !important;
}
.request-form{
  gap:12px !important;
  padding-bottom:6px !important;
}
.request-form input,
.request-form textarea,
.request-form select{
  min-height:48px !important;
  font-size:16px !important;
}
.request-form button[type="submit"]{
  position:sticky !important;
  bottom:0 !important;
  z-index:7 !important;
  box-shadow:0 -10px 30px rgba(255,255,255,.96) !important;
}
.whatsapp-submit{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
}
.wa-logo{
  width:22px !important;
  height:22px !important;
  color:#25D366 !important;
  display:inline-grid !important;
  place-items:center !important;
  flex:0 0 auto !important;
}
.wa-logo svg{
  width:22px !important;
  height:22px !important;
  display:block !important;
}
.checkout-list{
  gap:9px !important;
}
.checkout-list label{
  min-height:54px !important;
  padding:12px !important;
  border-radius:18px !important;
  font-size:15px !important;
  line-height:1.28 !important;
}
.checkout-list input{
  flex:0 0 auto !important;
  width:18px !important;
  height:18px !important;
}
@media(max-width:380px){
  :root{--tabbar-height:68px;--floating-tabbar-bottom:calc(var(--safe-bottom) + 10px);}
  .detail,.screen.detail{padding-left:14px !important;padding-right:14px !important;}
  .tile{min-height:96px !important;padding:12px !important;}
  .tile span{width:40px !important;height:40px !important;}
  .tile strong{font-size:14px !important;}
  .tile small{font-size:11.5px !important;}
  .tabbar{left:10px !important;right:10px !important;border-radius:26px !important;}
  .tab small{font-size:11px !important;}
  .panel-card{max-height:80dvh !important;padding-left:16px !important;padding-right:16px !important;}
}
@media(min-width:761px){
  .tabbar{
    left:50% !important;
    right:auto !important;
    width:min(720px,calc(100% - 28px)) !important;
    transform:translateX(-50%) !important;
  }
}

/* V1.1 — Production UX polish */
:root{
  --v11-safe-top: env(safe-area-inset-top, 0px);
  --v11-safe-bottom: env(safe-area-inset-bottom, 0px);
  --floating-tabbar-bottom: calc(var(--v11-safe-bottom) + 14px);
  --tabbar-height: 72px;
}
html,
body{
  touch-action: manipulation;
  -webkit-text-size-adjust: 100%;
}
body{
  padding-bottom:calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 18px) !important;
}
body.sheet-open{
  overflow:hidden;
  position:fixed;
  width:100%;
}
.app{
  min-height:100dvh;
  padding-bottom:calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 18px) !important;
}
.hero{
  min-height:450px !important;
  height:52vh !important;
  margin-top:calc(-1 * var(--v11-safe-top));
  padding-top:var(--v11-safe-top);
}
.hero-media{
  top:calc(-1 * var(--v11-safe-top));
  height:calc(100% + var(--v11-safe-top));
}
.topbar{
  padding:calc(16px + var(--v11-safe-top)) 18px 0 !important;
}
.lang{
  min-width:46px !important;
  width:46px !important;
  height:42px !important;
  padding:0 !important;
  display:grid;
  place-items:center;
  font-size:21px !important;
  letter-spacing:0 !important;
}
.hero-copy{
  bottom:70px !important;
  width:min(520px,calc(100% - 30px)) !important;
}
.eyebrow{
  height:28px !important;
  padding:0 12px !important;
  margin-bottom:14px !important;
  font-size:9px !important;
}
.hero h1,
.hero-copy h1{
  font-size:clamp(40px,10.5vw,66px) !important;
  line-height:.91 !important;
}
.hero p,
.hero-copy .subtitle{
  width:min(360px,94%) !important;
  margin-top:14px !important;
  font-size:14.5px !important;
  line-height:1.48 !important;
}
.hero p strong{
  display:block;
  margin-top:5px;
  color:#111;
  font-weight:760;
}
.actions{
  width:calc(100% - 24px) !important;
  margin:-54px auto calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 24px) !important;
}
.action-card,
.action-card-button{
  min-height:86px !important;
  margin-bottom:11px !important;
  padding:14px !important;
  grid-template-columns:50px 1fr 32px !important;
  border-radius:25px !important;
}
.action-card-button{
  width:100%;
  border:1px solid rgba(255,255,255,.72);
  text-align:left;
}
.icon-wrap{
  width:50px !important;
  height:50px !important;
  border-radius:17px !important;
}
.icon-wrap .lucide-icon{
  width:24px !important;
  height:24px !important;
}
.action-text strong{
  font-size:16px !important;
}
.action-text small{
  font-size:13px !important;
  line-height:1.25;
}
.chevron{
  width:32px !important;
  height:32px !important;
  font-size:24px !important;
}
.detail{
  padding:18px 14px calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 28px) !important;
}
.detail-header{
  margin-bottom:16px !important;
  gap:12px !important;
}
.detail-header span{
  display:block !important;
  margin-bottom:6px !important;
  font-size:10px !important;
  letter-spacing:.16em !important;
  color:rgba(0,0,0,.42) !important;
}
.detail-header h1{
  font-size:34px !important;
  line-height:.98 !important;
}
.detail-header p{
  margin-top:8px !important;
  font-size:14px !important;
  line-height:1.38 !important;
}
.tile-grid{
  gap:10px !important;
}
.tile{
  min-height:96px !important;
  padding:12px !important;
  border-radius:22px !important;
}
.tile span{
  width:40px !important;
  height:40px !important;
  border-radius:14px !important;
}
.tile span .lucide-icon{
  width:20px !important;
  height:20px !important;
}
.tile strong{
  font-size:14.5px !important;
}
.tile small{
  font-size:11px !important;
}
.tabbar{
  position:fixed !important;
  left:14px !important;
  right:14px !important;
  bottom:var(--floating-tabbar-bottom) !important;
  z-index:50 !important;
  height:var(--tabbar-height) !important;
  padding:8px 12px !important;
  border-radius:28px !important;
  border:1px solid rgba(0,0,0,.06) !important;
  background:rgba(255,255,255,.92) !important;
  backdrop-filter:blur(22px) saturate(1.25) !important;
  -webkit-backdrop-filter:blur(22px) saturate(1.25) !important;
  box-shadow:0 12px 36px rgba(0,0,0,.16) !important;
}
.tab{
  min-height:54px !important;
  gap:5px !important;
  padding-top:5px !important;
}
.tab::before{
  top:1px !important;
  width:16px !important;
  height:2px !important;
}
.tab span,
.tab span .lucide-icon{
  width:22px !important;
  height:22px !important;
}
.tab small{
  font-size:11.5px !important;
}
.panel{
  z-index:90 !important;
  align-items:flex-end !important;
  padding:0 12px calc(var(--v11-safe-bottom) + 14px) !important;
  background:rgba(0,0,0,.28) !important;
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
}
.panel-card{
  position:relative;
  width:100% !important;
  max-width:760px !important;
  max-height:min(82dvh,720px) !important;
  margin:0 auto !important;
  padding:0 !important;
  border-radius:30px !important;
  overflow:hidden !important;
  display:flex !important;
  flex-direction:column !important;
  background:#fff !important;
  box-shadow:0 -18px 60px rgba(0,0,0,.22) !important;
}
.panel-close{
  position:absolute !important;
  top:12px !important;
  right:12px !important;
  z-index:3 !important;
  width:42px !important;
  height:42px !important;
  padding:0 !important;
  border:0 !important;
  border-radius:999px !important;
  float:none !important;
  display:grid !important;
  place-items:center !important;
  background:#f2f2f2 !important;
  color:#111 !important;
  font-size:26px !important;
  line-height:1 !important;
  font-weight:500 !important;
}
#panelContent{
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding:22px 18px 18px;
}
#panelContent h2{
  margin:18px 52px 8px 0;
  font-size:30px;
  line-height:.98;
  letter-spacing:-.05em;
}
#panelContent p{
  margin:0 0 16px;
  color:rgba(0,0,0,.58);
  line-height:1.48;
  font-size:14.5px;
}
.wifi-premium{
  display:grid;
  gap:12px;
  margin-top:18px;
}
.wifi-premium > div{
  border-radius:22px;
  background:#f7f7f5;
  border:1px solid rgba(0,0,0,.055);
  padding:15px;
}
.wifi-premium span,
.info-block small{
  display:block;
  margin-bottom:6px;
  color:rgba(0,0,0,.48);
  font-size:11px;
  font-weight:850;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.wifi-premium strong,
.wifi-premium code{
  font-size:20px;
  font-weight:850;
  letter-spacing:-.03em;
  word-break:break-word;
}
.panel-main-cta,
.panel-secondary-link,
.request-form button[type="submit"],
.map-mini-card{
  -webkit-tap-highlight-color:transparent;
}
.panel-main-cta,
.request-form button[type="submit"]{
  width:100% !important;
  height:52px !important;
  border:0 !important;
  border-radius:18px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:9px;
  background:#111 !important;
  color:#fff !important;
  font-weight:850 !important;
  font-size:15px !important;
  margin-top:4px;
}
.panel-secondary-link{
  width:100%;
  min-height:48px;
  border:0;
  border-radius:18px;
  background:#f2f2f2;
  color:#111;
  font-weight:850;
  margin-top:14px;
}
.keybox-card{
  margin:16px 0;
  border-radius:24px;
  overflow:hidden;
  background:#f7f7f5;
  border:1px solid rgba(0,0,0,.055);
}
.keybox-card img{
  width:100%;
  display:block;
  max-height:260px;
  object-fit:cover;
}
.keybox-tags{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  padding:12px;
}
.keybox-tags span{
  min-height:28px;
  padding:0 10px;
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  background:#fff;
  font-size:12px;
  font-weight:800;
  color:rgba(0,0,0,.62);
}
.procedure-card{
  background:#f7f7f5 !important;
  border:1px solid rgba(0,0,0,.055) !important;
}
.step-list{
  margin:0;
  padding-left:20px;
  color:rgba(0,0,0,.72);
  line-height:1.55;
  font-size:14px;
}
.step-list li{margin:7px 0;}
.map-mini-card{
  display:grid;
  grid-template-columns:44px 1fr 24px;
  gap:12px;
  align-items:center;
  margin-top:16px;
  padding:14px;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(0,0,0,.055);
  box-shadow:0 8px 24px rgba(0,0,0,.045);
}
.map-mini-card > span{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:15px;
  background:#f2f2f2;
}
.map-mini-card strong{display:block;margin-bottom:3px;font-size:15px;}
.map-mini-card small{color:rgba(0,0,0,.52);font-weight:650;}
.equipment-list{
  display:grid;
  gap:10px;
  margin-top:16px;
}
.equipment-list div{
  min-height:52px;
  display:flex;
  gap:12px;
  align-items:center;
  padding:12px;
  border-radius:18px;
  background:#f7f7f5;
  border:1px solid rgba(0,0,0,.045);
}
.equipment-list span{
  width:24px;
  height:24px;
  display:grid;
  place-items:center;
  color:#111;
}
.clean-rules div{
  background:#f7f7f5 !important;
  border:1px solid rgba(0,0,0,.045);
}
.faq-accordion,
.sheet-faq{
  display:grid;
  gap:10px;
  margin-top:16px;
}
.faq-item{
  border-radius:20px;
  background:#f7f7f5;
  border:1px solid rgba(0,0,0,.045);
  overflow:hidden;
}
.faq-question{
  width:100%;
  border:0;
  background:transparent;
  padding:15px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  text-align:left;
  font-weight:850;
}
.faq-answer{
  display:none;
  padding:0 15px 15px;
  color:rgba(0,0,0,.6);
  line-height:1.45;
  font-size:14px;
}
.faq-item.is-open .faq-answer{display:block;}
.faq-item.is-open .faq-question span{transform:rotate(45deg);}
.request-form{
  display:grid;
  gap:12px;
  margin-top:16px;
  padding-bottom:8px;
}
.request-form h3{
  margin:12px 0 0;
  font-size:15px;
  letter-spacing:-.02em;
}
.request-form label{
  display:grid;
  gap:7px;
  font-weight:800;
  font-size:13px;
  color:rgba(0,0,0,.68);
}
.request-form input,
.request-form textarea,
.request-form select{
  width:100%;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  background:#f7f7f5;
  padding:13px 14px;
  font:inherit;
  font-size:15px;
  outline:none;
}
.request-form button[type="submit"]{
  position:sticky;
  bottom:0;
  z-index:2;
  box-shadow:0 -10px 24px rgba(255,255,255,.94),0 10px 28px rgba(0,0,0,.12);
}
.whatsapp-submit{
  background:#111 !important;
}
.wa-logo{
  width:22px;
  height:22px;
  color:#25D366;
  display:grid;
  place-items:center;
}
.wa-logo svg{width:22px;height:22px;display:block;}
.pro-fields{display:none;gap:12px;}
.pro-fields.is-visible{display:grid;}
.form-note{
  color:rgba(0,0,0,.48);
  line-height:1.35;
  font-size:12px;
}
.emergency-section{margin-top:18px;}
.emergency-section h3{margin:0 0 10px;font-size:16px;}
.emergency-list{
  display:grid;
  gap:10px;
}
.emergency-list a{
  min-height:50px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:13px 14px;
  border-radius:18px;
  background:#f7f7f5;
  border:1px solid rgba(0,0,0,.045);
  font-weight:850;
}
.assist-card.danger{
  background:#fff !important;
  color:#111 !important;
}
.assist-card.danger span{background:#f2f2f2 !important;}
.category-strip .chip span .lucide-icon{width:18px;height:18px;}
.top-picks{
  padding:16px 14px 13px !important;
}
.pick-card{
  height:348px !important;
}
.pick-card-img-wrap{
  height:154px !important;
  flex-basis:154px !important;
}
.map-card.more-card{
  border-radius:30px !important;
  background:#fff !important;
  box-shadow:0 12px 34px rgba(0,0,0,.07) !important;
}
.map-visual.map-preview{
  height:188px !important;
  background:#1f2d24 !important;
}
.map-visual.map-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(1.04) contrast(1.06) brightness(.9);
}
.map-content a{
  height:48px !important;
  border-radius:18px !important;
}
.top-detail-screen{
  padding-bottom:calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 24px) !important;
}
.top-hero{
  height:34vh !important;
  min-height:230px !important;
}
.top-content{
  margin:-34px auto 0 !important;
  border-radius:28px 28px 0 0 !important;
  padding:20px 16px calc(var(--tabbar-height) + var(--floating-tabbar-bottom) + 22px) !important;
}
.top-content h1{
  font-size:28px !important;
  margin-bottom:5px !important;
}
.top-content .type{
  margin-bottom:10px !important;
}
.info-chip-row{
  margin:12px 0 !important;
}
.top-block{
  margin-top:10px !important;
  padding:13px !important;
  border-radius:20px !important;
}
.top-block h3{
  margin-bottom:7px !important;
  font-size:15px !important;
}
.top-block p,
.top-block ul{
  font-size:13.5px !important;
  line-height:1.42 !important;
}
.try-capsules span{
  height:28px !important;
  font-size:12px !important;
}
.top-cta-full{
  height:50px !important;
  margin-top:14px !important;
  margin-bottom:0 !important;
}
@media(max-width:380px){
  .hero{min-height:420px !important;height:50vh !important;}
  .hero-copy{bottom:60px !important;}
  .hero h1,.hero-copy h1{font-size:38px !important;}
  .actions{margin-top:-46px !important;}
  .action-card,.action-card-button{min-height:80px !important;padding:12px !important;}
  .tile{min-height:90px !important;}
  .tabbar{left:10px !important;right:10px !important;}
}
@media(min-width:761px){
  .tabbar{
    left:50% !important;
    right:auto !important;
    width:min(760px,calc(100% - 28px)) !important;
    transform:translateX(-50%) !important;
  }
  .panel-card{border-radius:32px !important;}
  .hero{height:54vh !important;}
}
