*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Segoe UI',Roboto,Arial,sans-serif;overflow:hidden;background:#000510;color:#fff;height:100vh;cursor:grab}
body.dragging{cursor:grabbing}

#canvas{position:fixed;inset:0;z-index:0}

/* Google Map overlay */
.map-container{position:fixed;inset:0;z-index:1;background:#000;width:100%;height:100%}
.map-container iframe{width:100%;height:100%;border:none}

/* Top bar */
.top-bar{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;gap:16px;padding:12px 20px;background:linear-gradient(to bottom,rgba(0,0,0,.7),transparent)}
.brand{display:flex;align-items:center;gap:8px}
.brand-icon-img{width:36px;height:36px;filter:drop-shadow(0 2px 6px rgba(232,54,93,.4));transition:transform .2s}
.brand-icon-img:hover{transform:scale(1.15)}
.brand-icon{font-size:28px}
.brand-name{font-size:20px;font-weight:700;letter-spacing:-.5px}
.brand-tag{font-size:10px;padding:3px 8px;background:linear-gradient(135deg,#e91e63,#ff5722);border-radius:8px;font-weight:600;letter-spacing:.3px}

.search-wrap{position:relative;flex:1;max-width:480px}
.search-wrap input{width:100%;padding:10px 14px 10px 38px;background:rgba(255,255,255,.1);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-radius:24px;color:#fff;font-size:14px;outline:none;transition:all .3s}
.search-wrap input:focus{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.25);box-shadow:0 4px 24px rgba(0,0,0,.4)}
.search-wrap input::placeholder{color:rgba(255,255,255,.4)}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none;z-index:1}

.dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:rgba(20,20,40,.95);backdrop-filter:blur(20px);border-radius:14px;border:1px solid rgba(255,255,255,.08);overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.6);max-height:400px;overflow-y:auto}
.dropdown::-webkit-scrollbar{width:4px}
.dropdown::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}
.drop-item{display:flex;align-items:center;gap:12px;padding:11px 16px;cursor:pointer;transition:background .15s}
.drop-item:hover{background:rgba(255,255,255,.08)}
.drop-pin{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.drop-name{font-size:13px;font-weight:500}
.drop-meta{font-size:11px;color:rgba(255,255,255,.4)}
.drop-meta .stars{color:#fbbc04;font-size:10px}
.drop-label{font-size:9px;padding:2px 6px;border-radius:6px;font-weight:600;letter-spacing:.5px}
.drop-label.country{background:rgba(0,255,255,.15);color:#00ffff}

.back-btn{padding:8px 16px;background:rgba(255,255,255,.08);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);border-radius:20px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);white-space:nowrap}
.back-btn:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.25)}

.dash-link{padding:8px 14px;background:rgba(255,255,255,.08);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);border-radius:20px;color:#fff;font-size:13px;font-weight:500;text-decoration:none;transition:all .3s;white-space:nowrap}
.dash-link:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.25)}

.view-badge{padding:6px 14px;background:rgba(255,255,255,.08);border-radius:16px;font-size:12px;font-weight:500;letter-spacing:.5px;transition:all .5s cubic-bezier(.4,0,.2,1);white-space:nowrap}
.view-badge.is-street{background:linear-gradient(135deg,#e91e63,#ff5722);box-shadow:0 2px 12px rgba(233,30,99,.4)}

.hidden{display:none!important}

/* Tooltip */
.tooltip{position:fixed;z-index:110;padding:8px 16px;background:rgba(0,0,0,.85);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:8px;font-size:13px;font-weight:500;pointer-events:none;display:none;white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.5)}

/* Mascot */
.mascot{position:fixed;bottom:16px;right:16px;width:130px;height:150px;z-index:90;pointer-events:none;transition:transform .08s ease-out;transform-style:preserve-3d;perspective:600px}

/* Fly banner */
.fly-banner{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.75);backdrop-filter:blur(14px);padding:18px 30px;border-radius:14px;display:flex;align-items:center;gap:14px;font-size:15px;z-index:150;animation:fadeIn .3s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.fly-spinner{width:22px;height:22px;border:3px solid rgba(255,255,255,.15);border-top-color:#e91e63;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Popup overlay */
.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:190;animation:fadeIn .25s}

/* Popup */
.popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:440px;max-height:82vh;background:rgba(18,18,38,.96);backdrop-filter:blur(24px);border-radius:18px;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px rgba(0,0,0,.7);z-index:200;overflow:hidden;animation:popIn .35s cubic-bezier(.175,.885,.32,1.275)}
@keyframes popIn{from{opacity:0;transform:translate(-50%,-50%) scale(.88) translateY(20px)}to{opacity:1;transform:translate(-50%,-50%) scale(1) translateY(0)}}

.popup-head{display:flex;justify-content:space-between;align-items:flex-start;padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.06)}
.popup-head h2{font-size:17px;font-weight:600;margin-bottom:3px}
.popup-meta{display:flex;align-items:center;gap:6px;margin-bottom:2px}
.stars{color:#fbbc04;font-size:13px;letter-spacing:1px}
.popup-meta span:last-child{font-size:12px;color:rgba(255,255,255,.45)}
.popup-addr{font-size:12px;color:rgba(255,255,255,.35)}
.popup-x{background:rgba(255,255,255,.08);border:none;color:#fff;width:30px;height:30px;border-radius:50%;font-size:13px;cursor:pointer;flex-shrink:0}
.popup-x:hover{background:rgba(255,255,255,.15)}

.popup-body{padding:6px 18px 18px;overflow-y:auto;max-height:calc(82vh - 90px)}
.popup-body::-webkit-scrollbar{width:4px}
.popup-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}

/* Review cards */
.rv{padding:13px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.rv:last-child{border:none}
.rv-user{display:flex;align-items:center;gap:9px;margin-bottom:5px}
.rv-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:13px;flex-shrink:0}
.rv-name{font-size:12px;font-weight:500}
.rv-time{font-size:10px;color:rgba(255,255,255,.35)}
.rv-stars{color:#fbbc04;font-size:11px;letter-spacing:1px;margin-bottom:3px}
.rv-text{font-size:12.5px;line-height:1.55;color:rgba(255,255,255,.7)}

.resp-area{margin-top:8px}
.gen-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;background:linear-gradient(135deg,#e91e63,#ff5722);color:#fff;border:none;border-radius:16px;font-size:11px;cursor:pointer;transition:transform .2s,box-shadow .2s}
.gen-btn:hover{transform:scale(1.05);box-shadow:0 3px 14px rgba(233,30,99,.4)}
.gen-btn:disabled{opacity:.55;cursor:wait;transform:none}

.owner-resp{margin-top:8px;background:rgba(255,255,255,.04);border-radius:10px;padding:10px;border-left:3px solid #e91e63}
.owner-hdr{display:flex;align-items:center;gap:6px;margin-bottom:3px}
.owner-badge{font-size:10px;font-weight:600;color:#e91e63}
.owner-time{font-size:9px;color:rgba(255,255,255,.25)}
.owner-text{font-size:12.5px;line-height:1.55;color:rgba(255,255,255,.75)}

.resp-actions{display:flex;gap:5px;margin-top:6px}
.copy-btn,.regen-btn,.send-btn{padding:4px 9px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);border-radius:12px;font-size:10px;cursor:pointer;color:rgba(255,255,255,.5);transition:all .2s}
.copy-btn:hover,.regen-btn:hover{background:rgba(255,255,255,.08);color:#fff}
.send-btn{border-color:rgba(66,133,244,.3);color:#4285f4}
.send-btn:hover{background:rgba(66,133,244,.15);border-color:#4285f4;color:#fff}
.send-btn:disabled{opacity:.5;cursor:wait}
.copied{color:#4caf50!important;border-color:#4caf50!important}

.kw-tags{display:flex;gap:4px;margin-top:5px;flex-wrap:wrap}
.kw{background:rgba(233,30,99,.12);color:#ff80ab;padding:2px 7px;border-radius:8px;font-size:9px}

/* About button — pink-red neon */
.about-btn{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;border:2px solid rgba(233,30,99,.6);background:rgba(233,30,99,.15);backdrop-filter:blur(12px);color:#fff;font-size:20px;font-weight:700;cursor:pointer;z-index:95;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 0 15px rgba(233,30,99,.4),0 0 40px rgba(233,30,99,.15),inset 0 0 12px rgba(233,30,99,.1);display:flex;align-items:center;justify-content:center;padding:0;animation:neonPulse 2.5s ease-in-out infinite}
.about-btn-icon{width:36px;height:36px;filter:drop-shadow(0 0 6px rgba(233,30,99,.5));pointer-events:none}
.about-btn:hover{background:rgba(233,30,99,.25);transform:scale(1.12);box-shadow:0 0 20px rgba(233,30,99,.6),0 0 50px rgba(233,30,99,.25),inset 0 0 15px rgba(233,30,99,.15);border-color:rgba(255,50,120,.8)}
@keyframes neonPulse{0%,100%{box-shadow:0 0 15px rgba(233,30,99,.4),0 0 40px rgba(233,30,99,.15)}50%{box-shadow:0 0 20px rgba(233,30,99,.6),0 0 55px rgba(233,30,99,.25),0 0 80px rgba(233,30,99,.1)}}

/* About overlay */
.about-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:300;animation:aboutFadeIn .4s ease}
@keyframes aboutFadeIn{from{opacity:0;backdrop-filter:blur(0)}to{opacity:1;backdrop-filter:blur(12px)}}

/* About popup — glassmorphism card */
.about-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:420px;max-height:88vh;border-radius:24px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(160deg,rgba(30,30,70,.85) 0%,rgba(20,15,50,.9) 50%,rgba(40,20,60,.8) 100%);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);box-shadow:0 25px 80px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.05) inset,0 1px 0 rgba(255,255,255,.1) inset;z-index:310;overflow:hidden;overflow-y:auto;animation:aboutPopIn .5s cubic-bezier(.16,1,.3,1)}
@keyframes aboutPopIn{from{opacity:0;transform:translate(-50%,-50%) scale(.9) translateY(30px)}to{opacity:1;transform:translate(-50%,-50%) scale(1) translateY(0)}}
@keyframes aboutPopOut{from{opacity:1;transform:translate(-50%,-50%) scale(1) translateY(0)}to{opacity:0;transform:translate(-50%,-50%) scale(.92) translateY(20px)}}
@keyframes aboutFadeOut{from{opacity:1}to{opacity:0}}
.about-popup::-webkit-scrollbar{width:4px}
.about-popup::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}

/* About close button */
.about-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;border:none;background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);font-size:14px;cursor:pointer;z-index:5;transition:all .2s}
.about-close:hover{background:rgba(255,255,255,.15);color:#fff}

/* Hero area with mascot */
.about-hero{display:flex;justify-content:center;padding:32px 20px 8px;position:relative}
.about-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:180px;background:linear-gradient(135deg,rgba(233,30,99,.2),rgba(255,87,34,.12),rgba(100,60,180,.15));border-radius:24px 24px 0 0}
.about-mascot{width:130px;height:130px;position:relative;z-index:1;filter:drop-shadow(0 8px 30px rgba(233,30,99,.35));animation:mascotFloat 3s ease-in-out infinite}
@keyframes mascotFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Title */
.about-title{text-align:center;font-size:28px;font-weight:800;margin:10px 0 2px;background:linear-gradient(135deg,#fff,#ff80ab);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px}
.about-subtitle{text-align:center;font-size:13px;color:rgba(255,255,255,.5);margin-bottom:4px;letter-spacing:.3px;padding:0 20px;line-height:1.5}

/* Divider */
.about-divider{width:50px;height:3px;background:linear-gradient(90deg,#e91e63,#ff5722);border-radius:2px;margin:14px auto 18px}

/* Content */
.about-content{padding:0 24px}
.about-desc{font-size:12.5px;line-height:1.7;color:rgba(255,255,255,.55);margin-bottom:18px}
.about-section-title{font-size:14px;font-weight:700;margin:20px 0 12px;color:rgba(255,255,255,.85);letter-spacing:.3px}

/* Steps */
.about-step{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px}
.about-num{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#e91e63,#ff5722);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;box-shadow:0 3px 12px rgba(233,30,99,.3)}
.about-step strong{font-size:13px;display:block;margin-bottom:3px;color:rgba(255,255,255,.9)}
.about-step p{font-size:12px;line-height:1.6;color:rgba(255,255,255,.5);margin:0}

/* Footer */
.about-footer{margin-top:18px;padding-top:14px;border-top:1px solid rgba(255,255,255,.06);text-align:center}
.about-footer p{font-size:11px;color:rgba(255,255,255,.3);letter-spacing:.3px}

/* CTA button */
.about-cta{display:block;width:calc(100% - 48px);margin:20px 24px 24px;padding:14px;border:none;border-radius:14px;background:linear-gradient(135deg,#e91e63,#ff5722);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s;letter-spacing:.3px;box-shadow:0 4px 20px rgba(233,30,99,.3),inset 0 1px 0 rgba(255,255,255,.15)}
.about-cta:hover{transform:translateY(-1px);box-shadow:0 6px 28px rgba(233,30,99,.45)}

/* Contact button — mild orange neon */
.contact-btn{position:fixed;bottom:24px;left:24px;width:56px;height:56px;border-radius:50%;border:2px solid rgba(255,140,0,.6);background:rgba(255,140,0,.12);backdrop-filter:blur(12px);color:#fff;font-size:20px;font-weight:700;cursor:pointer;z-index:95;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 0 15px rgba(255,140,0,.35),0 0 40px rgba(255,140,0,.12),inset 0 0 12px rgba(255,140,0,.08);display:flex;align-items:center;justify-content:center;padding:0;animation:orangeNeonPulse 2.5s ease-in-out infinite}
.contact-btn-icon{width:34px;height:34px;filter:drop-shadow(0 0 6px rgba(255,140,0,.5));pointer-events:none}
.contact-btn:hover{background:rgba(255,140,0,.22);transform:scale(1.12);box-shadow:0 0 20px rgba(255,140,0,.5),0 0 50px rgba(255,140,0,.2),inset 0 0 15px rgba(255,140,0,.12);border-color:rgba(255,160,40,.8)}
@keyframes orangeNeonPulse{0%,100%{box-shadow:0 0 15px rgba(255,140,0,.35),0 0 40px rgba(255,140,0,.12)}50%{box-shadow:0 0 20px rgba(255,140,0,.5),0 0 55px rgba(255,140,0,.2),0 0 80px rgba(255,140,0,.08)}}

/* Contact overlay */
.contact-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:300;animation:aboutFadeIn .4s ease}

/* Contact popup */
.contact-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:400px;max-height:88vh;border-radius:24px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(160deg,rgba(40,30,20,.9) 0%,rgba(30,20,15,.92) 50%,rgba(50,30,10,.85) 100%);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);box-shadow:0 25px 80px rgba(0,0,0,.5),0 0 60px rgba(255,140,0,.08),0 0 0 1px rgba(255,255,255,.05) inset;z-index:310;overflow:hidden;overflow-y:auto;animation:aboutPopIn .5s cubic-bezier(.16,1,.3,1)}
.contact-popup::-webkit-scrollbar{width:4px}
.contact-popup::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}

.contact-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;border:none;background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);font-size:14px;cursor:pointer;z-index:5;transition:all .2s}
.contact-close:hover{background:rgba(255,255,255,.15);color:#fff}

.contact-hero{display:flex;justify-content:center;padding:28px 20px 8px;position:relative}
.contact-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:150px;background:linear-gradient(135deg,rgba(255,140,0,.15),rgba(255,100,0,.1),rgba(255,180,60,.1));border-radius:24px 24px 0 0}
.contact-mascot{width:90px;height:90px;position:relative;z-index:1;filter:drop-shadow(0 8px 30px rgba(255,140,0,.3));animation:mascotFloat 3s ease-in-out infinite}

.contact-title{text-align:center;font-size:24px;font-weight:800;margin:10px 0 2px;background:linear-gradient(135deg,#fff,#ffb74d);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.contact-subtitle{text-align:center;font-size:12px;color:rgba(255,255,255,.45);margin-bottom:4px;padding:0 20px}
.contact-divider{width:50px;height:3px;background:linear-gradient(90deg,#ff8c00,#ffa726);border-radius:2px;margin:12px auto 18px}

.contact-form{padding:0 24px}
.contact-form input,.contact-form textarea{width:100%;padding:11px 14px;margin-bottom:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:13px;font-family:inherit;outline:none;transition:all .3s;resize:none}
.contact-form input:focus,.contact-form textarea:focus{border-color:rgba(255,140,0,.4);background:rgba(255,255,255,.1);box-shadow:0 0 12px rgba(255,140,0,.1)}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(255,255,255,.3)}

.contact-submit{display:flex;align-items:center;justify-content:center;width:100%;padding:13px;border:none;border-radius:14px;background:linear-gradient(135deg,#ff8c00,#ffa726);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 20px rgba(255,140,0,.25);margin-bottom:20px}
.contact-submit:hover{transform:translateY(-1px);box-shadow:0 6px 28px rgba(255,140,0,.4)}

.contact-status{text-align:center;padding:0 24px 16px;font-size:12px;color:#4caf50}

/* City selector panel */
.city-selector{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:420px;max-height:75vh;border-radius:20px;border:1px solid rgba(255,255,255,.12);background:rgba(12,12,30,.95);backdrop-filter:blur(24px);box-shadow:0 20px 60px rgba(0,0,0,.6);z-index:160;overflow:hidden;animation:popIn .35s cubic-bezier(.175,.885,.32,1.275)}
.city-selector-header{padding:20px 20px 10px;text-align:center}
.city-selector-header h3{font-size:18px;font-weight:700;margin-bottom:4px}
.city-selector-header p{font-size:12px;color:rgba(255,255,255,.4)}
.city-search-wrap{padding:0 16px 10px}
.city-search-wrap input{width:100%;padding:10px 14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:13px;outline:none;transition:all .3s}
.city-search-wrap input:focus{border-color:rgba(0,255,255,.3);background:rgba(255,255,255,.12)}
.city-search-wrap input::placeholder{color:rgba(255,255,255,.3)}
.city-list{max-height:calc(75vh - 200px);overflow-y:auto;padding:0 8px}
.city-list::-webkit-scrollbar{width:4px}
.city-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}
.city-item{display:flex;align-items:center;gap:10px;padding:11px 14px;margin:2px 0;border-radius:10px;cursor:pointer;transition:background .15s}
.city-item:hover{background:rgba(0,255,255,.08)}
.city-item .city-dot{width:8px;height:8px;border-radius:50%;background:#00ffcc;flex-shrink:0;box-shadow:0 0 6px rgba(0,255,204,.4)}
.city-item .city-name{font-size:13px;font-weight:500}
.city-item .city-region{font-size:11px;color:rgba(255,255,255,.35)}
.city-skip{display:block;width:calc(100% - 32px);margin:10px 16px 16px;padding:12px;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:rgba(255,255,255,.04);color:rgba(255,255,255,.6);font-size:13px;cursor:pointer;transition:all .2s}
.city-skip:hover{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.2)}

/* ═══ MOBILE ═══ */
@media(max-width:600px){
  /* Top bar: two rows */
  .top-bar{flex-wrap:wrap;gap:8px;padding:10px 12px}
  .brand{gap:6px}
  .brand-icon-img{width:28px;height:28px}
  .brand-name{font-size:16px}
  .brand-tag{font-size:8px;padding:2px 6px}

  /* Search takes full width on second row */
  .search-wrap{order:10;flex-basis:100%;max-width:100%}
  .search-wrap input{padding:10px 14px 10px 34px;font-size:13px}
  .search-icon{font-size:13px;left:12px}

  .back-btn{padding:6px 10px;font-size:11px}
  .view-badge{padding:4px 10px;font-size:10px;max-width:120px;overflow:hidden;text-overflow:ellipsis}

  /* Dropdown */
  .dropdown{max-height:50vh;border-radius:12px}
  .drop-item{padding:10px 12px;gap:10px}
  .drop-pin{width:28px;height:28px;font-size:13px}
  .drop-name{font-size:12px}
  .drop-meta{font-size:10px}

  /* Tooltip — hide on mobile (no hover) */
  .tooltip{display:none!important}

  /* Contact */
  .contact-btn{bottom:16px;left:16px;width:50px;height:50px}
  .contact-btn-icon{width:30px;height:30px}
  .contact-popup{width:calc(100% - 20px);max-height:90vh;border-radius:20px}
  .contact-form{padding:0 16px}
  .contact-submit{margin-bottom:16px}

  /* City selector */
  .city-selector{width:calc(100% - 20px)}

  /* About */
  .about-btn{bottom:16px;right:16px;width:50px;height:50px;z-index:95}
  .about-btn-icon{width:32px;height:32px}
  .about-popup{width:calc(100% - 20px);max-height:90vh;border-radius:20px}
  .about-mascot{width:100px;height:100px}
  .about-title{font-size:22px}
  .about-subtitle{font-size:12px}
  .about-content{padding:0 16px}
  .about-desc{font-size:12px}
  .about-step p{font-size:11.5px}
  .about-cta{width:calc(100% - 32px);margin:16px 16px 20px}

  /* Fly banner */
  .fly-banner{padding:14px 20px;font-size:13px;border-radius:12px;width:80%;justify-content:center}

  /* Popup — full width on mobile */
  .popup{width:calc(100% - 24px);max-height:88vh;border-radius:14px}
  .popup-head{padding:14px 14px 12px}
  .popup-head h2{font-size:15px}
  .popup-body{padding:4px 14px 14px;max-height:calc(88vh - 80px)}

  /* Review cards */
  .rv{padding:10px 0}
  .rv-text{font-size:12px}
  .gen-btn{font-size:10px;padding:6px 11px}
  .owner-resp{padding:8px}
  .owner-text{font-size:12px}
  .resp-actions{flex-wrap:wrap;gap:4px}
  .copy-btn,.regen-btn,.send-btn{font-size:9px;padding:4px 8px}
}

/* ═══ TABLET ═══ */
@media(min-width:601px) and (max-width:900px){
  .top-bar{gap:10px;padding:10px 14px}
  .brand-name{font-size:18px}
  .search-wrap{max-width:320px}
  .popup{width:400px}
}
