/* =============================================
   LoveConnect Zimbabwe - Full Stylesheet
   ============================================= */
:root {
  --primary: #e91e63;
  --primary-dark: #c2185b;
  --primary-light: #f48fb1;
  --whatsapp: #25d366;
  --bg: #f5f5f5;
  --card-bg: #ffffff;
  --text: #212121;
  --text-muted: #757575;
  --border: #e0e0e0;
  --shadow: 0 4px 20px rgba(0,0,0,0.1);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.18);
  --radius: 16px;
  --radius-sm: 8px;
  --nav-height: 64px;
  --bottom-nav-height: 64px;
  --gradient: linear-gradient(135deg, #e91e63, #ff5722);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Poppins',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-height);background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.08);display:flex;align-items:center;justify-content:space-between;padding:0 24px}
.nav-brand{display:flex;align-items:center;gap:8px;font-size:1.3rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-brand i{-webkit-text-fill-color:#e91e63}
.nav-links{display:flex;gap:4px}
.nav-link{display:flex;flex-direction:column;align-items:center;padding:6px 14px;border-radius:var(--radius-sm);text-decoration:none;color:var(--text-muted);font-size:.7rem;font-weight:500;transition:all .2s;gap:2px}
.nav-link i{font-size:1.1rem}
.nav-link:hover,.nav-link.active{color:var(--primary);background:rgba(233,30,99,.08)}
@media(max-width:600px){.navbar{display:none}}
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;height:var(--bottom-nav-height);background:#fff;box-shadow:0 -2px 12px rgba(0,0,0,.1);display:none;align-items:center;justify-content:space-around;padding:0 8px}
.bottom-nav-link{display:flex;flex-direction:column;align-items:center;text-decoration:none;color:var(--text-muted);font-size:.65rem;gap:2px;padding:6px 16px;transition:color .2s}
.bottom-nav-link i{font-size:1.3rem}
.bottom-nav-link.active{color:var(--primary)}
@media(max-width:600px){.bottom-nav{display:flex}}
.main-content{min-height:100vh}
.main-content.with-nav{padding-top:var(--nav-height);padding-bottom:var(--bottom-nav-height)}
@media(max-width:600px){.main-content.with-nav{padding-top:0}}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:50px;border:none;font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s;line-height:1}
.btn-primary{background:var(--gradient);color:#fff}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(233,30,99,.4)}
.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-outline:hover{background:rgba(233,30,99,.08)}
.btn-whatsapp{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff}
.btn-whatsapp:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(37,211,102,.4)}
.btn-danger{background:linear-gradient(135deg,#f44336,#c62828);color:#fff}
.btn-success{background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff}
.btn-lg{padding:16px 32px;font-size:1.05rem}
.btn-sm{padding:8px 16px;font-size:.82rem}
.btn-full{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}
.alert{padding:14px 18px;border-radius:var(--radius-sm);margin-bottom:16px;display:flex;align-items:center;gap:10px;font-size:.9rem}
.alert-error{background:#fce4ec;color:#c62828;border-left:4px solid #e91e63}
.alert-success{background:#e8f5e9;color:#2e7d32;border-left:4px solid #4caf50}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px;color:#444}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;transition:border-color .2s;background:#fafafa;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);background:#fff}
.form-group textarea{resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.form-section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--primary);margin:20px 0 10px;border-bottom:2px solid var(--primary-light);padding-bottom:4px}
.input-toggle{position:relative;display:flex}
.input-toggle input{flex:1;padding-right:48px}
.toggle-btn{position:absolute;right:0;top:0;bottom:0;width:44px;background:transparent;border:none;cursor:pointer;color:var(--text-muted)}
.terms-note{background:#fff8e1;border-radius:var(--radius-sm);padding:12px 16px;font-size:.82rem;color:#795548;margin-bottom:16px;display:flex;gap:8px}
.photo-upload-area{position:relative;width:160px;height:160px;border-radius:50%;overflow:hidden;cursor:pointer;margin:0 auto 8px;border:3px solid var(--primary-light)}
.photo-upload-area img{width:100%;height:100%;object-fit:cover}
.photo-upload-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity .2s;font-size:.8rem;gap:4px}
.photo-upload-area:hover .photo-upload-overlay{opacity:1}
.photo-upload-overlay i{font-size:1.4rem}
.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#e91e63 0%,#ff5722 50%,#ff9800 100%)}
.register-container{align-items:flex-start;padding:40px 20px}
.auth-card{background:#fff;border-radius:24px;padding:40px 36px;width:100%;max-width:560px;box-shadow:var(--shadow-lg)}
@media(max-width:600px){.auth-card{padding:28px 20px;border-radius:20px}}
.auth-header{text-align:center;margin-bottom:28px}
.auth-logo{width:70px;height:70px;background:var(--gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;margin:0 auto 16px}
.auth-header h1{font-size:1.8rem;font-weight:800;color:var(--text)}
.auth-header p{color:var(--text-muted);margin-top:4px}
.auth-form{display:flex;flex-direction:column}
.auth-footer{text-align:center;margin-top:20px;color:var(--text-muted);font-size:.9rem}
.auth-footer a{color:var(--primary);font-weight:600;text-decoration:none}
.hero-section{position:relative;min-height:100vh;background:linear-gradient(135deg,#1a0a0f 0%,#4a0e1e 40%,#7b1fa2 100%);display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-content{position:relative;text-align:center;color:#fff;padding:40px 24px;max-width:700px}
.zw-flag-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);backdrop-filter:blur(10px);border-radius:50px;padding:8px 20px;font-size:.9rem;font-weight:600;margin-bottom:24px}
.hero-title{font-size:clamp(2.4rem,6vw,4rem);font-weight:800;line-height:1.1;margin-bottom:16px}
.hero-title .highlight{background:linear-gradient(135deg,#f48fb1,#ff9800);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{font-size:1.1rem;opacity:.85;max-width:500px;margin:0 auto 32px;line-height:1.6}
.hero-stats{display:flex;justify-content:center;gap:40px;margin-bottom:32px}
.stat{display:flex;flex-direction:column;align-items:center}
.stat strong{font-size:2rem;font-weight:800}
.stat span{font-size:.8rem;opacity:.7;text-transform:uppercase;letter-spacing:1px}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
@media(max-width:480px){.hero-stats{gap:24px}.stat strong{font-size:1.5rem}}
.features-section{padding:80px 0;background:#fff}
.section-title{text-align:center;font-size:2rem;font-weight:800;margin-bottom:48px;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.feature-card{background:var(--bg);border-radius:var(--radius);padding:32px 24px;text-align:center;transition:transform .2s,box-shadow .2s}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.feature-icon{width:64px;height:64px;background:var(--gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:#fff;margin:0 auto 16px}
.feature-card h3{font-size:1.1rem;font-weight:700;margin-bottom:8px}
.feature-card p{color:var(--text-muted);font-size:.9rem;line-height:1.6}
.how-it-works{padding:80px 0;background:linear-gradient(135deg,#fce4ec,#fff8e1)}
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;max-width:900px;margin:0 auto}
.step{text-align:center}
.step-num{width:60px;height:60px;background:var(--gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;font-weight:800;color:#fff;margin:0 auto 16px}
.step h3{font-size:1.1rem;font-weight:700;margin-bottom:8px}
.step p{color:var(--text-muted);font-size:.9rem;line-height:1.5}
.site-footer{background:#1a0a0f;color:rgba(255,255,255,.7);text-align:center;padding:40px 20px}
.footer-brand{font-size:1.3rem;font-weight:800;color:#e91e63;margin-bottom:12px}
.discover-page{max-width:500px;margin:0 auto;padding:20px 16px}
.discover-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.discover-header h2{font-size:1.4rem;font-weight:800}
.filter-bar{display:flex;align-items:center;gap:8px}
.filter-select{padding:8px 12px;border-radius:50px;border:2px solid var(--border);font-family:inherit;font-size:.82rem;background:#fff}
.card-stack-container{position:relative}
.card-stack{position:relative;height:540px;margin-bottom:16px}
@media(max-width:480px){.card-stack{height:480px}}
.swipe-card{position:absolute;inset:0;border-radius:20px;overflow:hidden;cursor:grab;user-select:none;box-shadow:var(--shadow-lg);touch-action:none;transform-origin:center bottom}
.swipe-card:active{cursor:grabbing}
.card-image{width:100%;height:100%;background-size:cover;background-position:center top;position:relative}
.card-gradient{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.3) 50%,transparent 100%)}
.swipe-indicator{position:absolute;top:40px;padding:10px 20px;border-radius:8px;font-size:1.4rem;font-weight:900;opacity:0;transition:opacity .1s;border:4px solid;z-index:10}
.like-indicator{left:20px;color:#4caf50;border-color:#4caf50;transform:rotate(-15deg)}
.nope-indicator{right:20px;color:#f44336;border-color:#f44336;transform:rotate(15deg)}
.card-info{position:absolute;bottom:0;left:0;right:0;color:#fff;padding:20px}
.card-main-info h2{font-size:1.6rem;font-weight:800;line-height:1.1}
.card-location{font-size:.9rem;opacity:.85;margin:4px 0 8px}
.card-bio{font-size:.88rem;opacity:.85;line-height:1.4;margin-bottom:8px}
.card-interests{display:flex;gap:6px;flex-wrap:wrap}
.interest-tag{background:rgba(255,255,255,.2);backdrop-filter:blur(4px);border-radius:50px;padding:4px 12px;font-size:.78rem;font-weight:600;color:#fff;border:1px solid rgba(255,255,255,.3)}
.card-expand-btn{position:absolute;top:16px;right:16px;width:40px;height:40px;background:rgba(255,255,255,.2);backdrop-filter:blur(8px);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;font-size:1.1rem;z-index:10}
.action-buttons{display:flex;justify-content:center;align-items:center;gap:20px;margin-bottom:12px}
.action-btn{border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s;box-shadow:var(--shadow)}
.action-btn:active{transform:scale(.92)!important}
.nope-btn{width:64px;height:64px;background:#fff;color:#f44336;font-size:1.5rem}
.nope-btn:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(244,67,54,.3)}
.superlike-btn{width:54px;height:54px;background:#fff;color:#2196f3;font-size:1.2rem}
.superlike-btn:hover{transform:scale(1.08)}
.like-btn{width:72px;height:72px;background:var(--gradient);color:#fff;font-size:1.6rem}
.like-btn:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(233,30,99,.4)}
.card-counter{text-align:center;font-size:.85rem;color:var(--text-muted)}
.match-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;backdrop-filter:blur(4px)}
.match-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:201;background:#fff;border-radius:28px;padding:40px 32px;text-align:center;max-width:360px;width:calc(100% - 40px);box-shadow:0 20px 60px rgba(0,0,0,.3);animation:popIn .4s cubic-bezier(.175,.885,.32,1.275)}
@keyframes popIn{from{transform:translate(-50%,-50%) scale(.7);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}
.match-popup h2{font-size:2rem;font-weight:800;color:var(--primary);margin-bottom:8px}
.match-popup p{color:var(--text-muted);margin-bottom:24px}
.match-avatars{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:24px}
.match-avatar{width:100px;height:100px;border-radius:50%;object-fit:cover;border:4px solid #fff;box-shadow:var(--shadow)}
.match-heart-icon{width:44px;height:44px;background:var(--gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;margin:0 -10px;z-index:1;box-shadow:var(--shadow)}
.match-actions{display:flex;flex-direction:column;gap:10px}
.heart-burst{font-size:3rem;margin-bottom:12px;animation:heartBeat .6s ease-in-out infinite alternate}
.heart-burst::before{content:'❤️'}
@keyframes heartBeat{from{transform:scale(1)}to{transform:scale(1.2)}}
.empty-state{text-align:center;padding:60px 24px}
.empty-icon{font-size:4rem;margin-bottom:16px;color:var(--primary-light)}
.empty-state h3{font-size:1.4rem;font-weight:700;margin-bottom:8px}
.empty-state p{color:var(--text-muted);margin-bottom:24px}
.matches-page{max-width:700px;margin:0 auto;padding:20px 16px}
.matches-header{margin-bottom:16px}
.matches-header h2{font-size:1.4rem;font-weight:800}
.matches-tabs{display:flex;gap:0;margin-bottom:20px;background:var(--bg);border-radius:50px;padding:4px}
.tab-btn{flex:1;padding:10px;border:none;background:transparent;border-radius:50px;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}
.tab-btn.active{background:#fff;color:var(--primary);box-shadow:var(--shadow)}
.badge{background:var(--primary);color:#fff;border-radius:50px;padding:2px 8px;font-size:.75rem;font-weight:700}
.matches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.match-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.match-card-photo{height:200px;background-size:cover;background-position:center;position:relative}
.match-card-gradient{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6),transparent)}
.online-dot{position:absolute;top:12px;right:12px;width:14px;height:14px;border-radius:50%;background:#aaa;border:2px solid #fff}
.online-dot.online{background:var(--whatsapp)}
.match-card-info{padding:16px}
.match-card-name{font-size:1.1rem;font-weight:700;margin-bottom:4px}
.match-card-location{font-size:.82rem;color:var(--text-muted);margin-bottom:4px}
.match-card-time{font-size:.78rem;color:var(--primary-light);margin-bottom:12px}
.match-card-actions{display:flex;gap:8px}
.admirer-card{background:#fff;border-radius:var(--radius-sm);padding:16px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow);margin-bottom:12px}
.admirer-photo{width:64px;height:64px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--primary-light)}
.admirer-info{flex:1}
.admirer-info strong{display:block;font-size:1rem;font-weight:700}
.admirer-info span{font-size:.82rem;color:var(--text-muted)}
.admirer-info p{font-size:.82rem;color:#555;margin-top:4px}
.admirer-actions{display:flex;flex-direction:column;gap:6px}
.map-page{padding:16px;max-width:1000px;margin:0 auto}
.map-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.map-header h2{font-size:1.4rem;font-weight:800}
.map-controls{display:flex;gap:8px;flex-wrap:wrap}
.map-stats-bar{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px}
.map-stat{font-size:.85rem;color:var(--text-muted);display:flex;align-items:center;gap:6px}
.map-stat-warn{color:#f57c00}
.leaflet-map{height:60vh;min-height:360px;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.province-jumper{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.province-btn{padding:6px 14px;border-radius:50px;border:2px solid var(--primary);background:transparent;color:var(--primary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}
.province-btn:hover{background:var(--primary);color:#fff}
.map-marker{width:44px;height:44px;border-radius:50%;overflow:hidden;border:3px solid var(--primary);box-shadow:0 2px 8px rgba(0,0,0,.3);background:var(--bg)}
.map-marker img{width:100%;height:100%;object-fit:cover}
.me-marker{border-color:var(--whatsapp);width:50px;height:50px}
.online-marker{border-color:var(--whatsapp)}
.marker-pulse{position:absolute;inset:-6px;border-radius:50%;border:3px solid var(--whatsapp);opacity:0;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.4);opacity:0}}
.map-popup{display:flex;flex-direction:column;gap:8px;min-width:200px}
.popup-photo{width:100%;height:120px;object-fit:cover;border-radius:8px}
.popup-info{display:flex;flex-direction:column;gap:4px}
.popup-info strong{font-size:1rem;font-weight:700}
.popup-info span{font-size:.8rem;color:var(--text-muted)}
.popup-info p{font-size:.8rem;color:#555}
.online-badge{color:var(--whatsapp);font-size:.78rem;font-weight:600}
.popup-btn{display:inline-block;background:var(--gradient);color:#fff;padding:8px 16px;border-radius:50px;font-size:.82rem;font-weight:600;text-decoration:none;text-align:center;margin-top:4px}
.profile-page{max-width:700px;margin:0 auto;padding:20px 16px}
.profile-hero{background:#fff;border-radius:var(--radius);padding:28px 24px;display:flex;gap:24px;align-items:flex-start;margin-bottom:20px;box-shadow:var(--shadow)}
@media(max-width:600px){.profile-hero{flex-direction:column;align-items:center;text-align:center}}
.profile-hero-photo{position:relative;flex-shrink:0}
.profile-hero-photo img{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--primary-light)}
.quick-photo-btn{position:absolute;bottom:4px;right:4px;width:32px;height:32px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.85rem;cursor:pointer}
.profile-hero-info h1{font-size:1.4rem;font-weight:800;margin-bottom:4px}
.profile-location{color:var(--text-muted);font-size:.9rem;margin-bottom:8px}
.profile-bio-preview{font-size:.88rem;color:#555;margin-bottom:12px}
.profile-stats{display:flex;gap:24px}
.pstat{text-align:center}
.pstat strong{display:block;font-size:1.2rem;font-weight:800;color:var(--primary)}
.pstat span{font-size:.72rem;color:var(--text-muted);text-transform:uppercase}
.profile-edit-card{background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.profile-edit-card h3{font-size:1.1rem;font-weight:700;margin-bottom:20px;color:var(--primary)}
.danger-zone{margin-top:32px;border-top:2px solid #fce4ec;padding-top:20px}
.danger-zone h4{color:#c62828;margin-bottom:12px;font-size:.9rem}
.view-profile-page{max-width:600px;margin:0 auto;padding:20px 16px}
.view-profile-back{margin-bottom:16px}
.view-profile-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.view-profile-photo-wrap{position:relative}
.view-profile-photo{width:100%;height:420px;object-fit:cover;object-position:top}
@media(max-width:480px){.view-profile-photo{height:320px}}
.match-badge-overlay{position:absolute;top:16px;left:16px;background:var(--gradient);color:#fff;padding:8px 16px;border-radius:50px;font-size:.88rem;font-weight:700}
.view-profile-info{padding:24px}
.view-profile-name-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.view-profile-name-row h1{font-size:1.6rem;font-weight:800}
.view-profile-age{background:var(--gradient);color:#fff;padding:4px 12px;border-radius:50px;font-size:1rem;font-weight:700}
.view-profile-meta{display:flex;flex-wrap:wrap;gap:12px;color:var(--text-muted);font-size:.85rem;margin-bottom:20px}
.view-profile-meta span{display:flex;align-items:center;gap:4px}
.view-profile-bio,.view-profile-interests,.view-profile-details{margin-bottom:20px}
.view-profile-bio h3,.view-profile-interests h3,.view-profile-details h3{font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:var(--primary);font-weight:700;margin-bottom:8px}
.view-profile-bio p{color:#444;line-height:1.7;font-size:.95rem}
.interests-tags{display:flex;flex-wrap:wrap;gap:8px}
.view-profile-details{display:flex;flex-wrap:wrap;gap:12px}
.detail-item{display:flex;align-items:center;gap:6px;background:var(--bg);padding:8px 14px;border-radius:50px;font-size:.85rem;color:#444}
.detail-item i{color:var(--primary)}
.view-profile-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.match-info-note{text-align:center;color:var(--text-muted);font-size:.88rem}
.tab-content{display:none}
.tab-content.active{display:block}
.match-modal{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;padding:20px}
.match-modal-inner{background:#fff;border-radius:24px;padding:40px 28px;text-align:center;max-width:340px;width:100%;animation:popIn .4s cubic-bezier(.175,.885,.32,1.275)}
.match-modal-inner h2{font-size:1.8rem;font-weight:800;color:var(--primary);margin:12px 0 8px}
.match-modal-inner p{color:var(--text-muted);margin-bottom:20px}
@media(max-width:768px){.matches-grid{grid-template-columns:1fr}}
@media(max-width:480px){.discover-page,.matches-page,.profile-page,.view-profile-page{padding:12px 10px}.auth-card{padding:24px 16px}.map-page{padding:10px}.leaflet-map{height:50vh}}
.leaflet-popup-content-wrapper{border-radius:12px!important;padding:0!important}
.leaflet-popup-content{margin:12px!important}
.leaflet-container{font-family:'Poppins',sans-serif!important}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--primary-light);border-radius:3px}
.pulse-dot{width:8px;height:8px;background:#4caf50;border-radius:50%;display:inline-block;animation:pulse 1.5s infinite;margin-right:4px}
.vp-online-badge{background:rgba(76,175,80,.15);color:#2e7d32;padding:4px 12px;border-radius:50px;font-size:.8rem;font-weight:600;margin-bottom:12px;display:inline-flex;align-items:center;gap:4px}

/* =============================================
   MOBILE & USABILITY IMPROVEMENTS
   ============================================= */

/* Better touch targets for mobile */
@media (max-width: 768px) {
    .btn { min-height: 48px; min-width: 48px; padding: 14px 24px; }
    .action-btn { min-width: 56px; min-height: 56px; }
    .like-btn { width: 76px; height: 76px; }
    .nope-btn { width: 68px; height: 68px; }
    .superlike-btn { width: 58px; height: 58px; }
    .bottom-nav-link { min-height: 44px; padding: 8px 12px; }
    .nav-link { min-height: 44px; padding: 8px 16px; }
    input, select, textarea { font-size: 16px !important; /* Prevent iOS zoom */ }
    .form-group input, .form-group select, .form-group textarea { min-height: 48px; }
}

/* Desktop enhancements */
@media (min-width: 1024px) {
    .discover-page { max-width: 600px; }
    .card-stack { height: 620px; }
    .matches-page { max-width: 900px; }
    .matches-grid { grid-template-columns: repeat(3, 1fr); }
    .admin-grid { grid-template-columns: 2fr 1fr; }
}

/* Large desktop */
@media (min-width: 1440px) {
    .container { max-width: 1400px; }
    .discover-page { max-width: 650px; }
    .card-stack { height: 680px; }
}

/* Better focus states for keyboard navigation */
.btn:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible, a:focus-visible {
    outline: 3px solid var(--primary);
    outline-offset: 2px;
}

/* Improve swipe card visibility */
.swipe-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border: 3px solid transparent;
    border-radius: 20px;
    pointer-events: none;
    transition: border-color 0.2s;
}
.swipe-card:hover::before {
    border-color: rgba(233,30,99,0.3);
}

/* Better scrolling on iOS */
@media (max-width: 768px) {
    .main-content {
        -webkit-overflow-scrolling: touch;
    }
    .bottom-nav {
        padding-bottom: env(safe-area-inset-bottom, 0);
    }
}

/* Dark mode support (optional) */
@media (prefers-color-scheme: dark) {
    /* Auto-adjust for users with dark mode preference */
    html { color-scheme: light; } /* Keep app in light mode for consistency */
}

/* Reduce motion for accessibility */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Print styles */
@media print {
    .navbar, .bottom-nav, .action-buttons, .filter-bar { display: none !important; }
    body { background: #fff; }
    .main-content { padding: 0 !important; }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .btn { border: 2px solid currentColor; }
    .badge { border: 1px solid currentColor; }
}
