/*
Theme Name: Gluten-Free Holiday
Theme URI: https://glutenfreeholiday.com
Author: Gluten-Free Holiday Team
Description: Professional gluten-free travel directory - restaurants, hotels and travel locations worldwide.
Version: 2.0.0
License: GNU General Public License v2 or later
Text Domain: gfh
Tags: travel, directory, restaurant, hotel, gluten-free, map, reviews
*/

/* ===========================
   CSS VARIABLES
   =========================== */
:root {
  --primary: #2E7D52;
  --primary-light: #4CAF76;
  --primary-dark: #1B5E38;
  --primary-glow: rgba(46,125,82,0.2);
  --accent: #F0FFF4;
  --gold: #C9993A;
  --salmon: #E8847A;
  --text-dark: #1A1A2E;
  --text-mid: #4A5568;
  --text-soft: #718096;
  --bg-white: #FFFFFF;
  --bg-light: #F7FAF8;
  --bg-grey: #EEF2EF;
  --border: #E2EBE5;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.06);
  --shadow-md: 0 6px 24px rgba(0,0,0,0.10);
  --shadow-lg: 0 12px 48px rgba(0,0,0,0.14);
  --shadow-green: 0 8px 32px rgba(46,125,82,0.18);
  --radius: 14px;
  --radius-sm: 8px;
  --radius-lg: 24px;
  --t: all 0.25s ease;
  --font-head: 'Playfair Display', Georgia, serif;
  --font-body: 'DM Sans', 'Helvetica Neue', sans-serif;
}

/* ===========================
   RESET & BASE
   =========================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--text-dark);background:var(--bg-white);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:var(--t)}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit}
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:700;line-height:1.25}
h1{font-size:clamp(2.2rem,5vw,3.8rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.6rem)}
h3{font-size:clamp(1.2rem,2vw,1.6rem)}
p{line-height:1.75;color:var(--text-mid)}

/* ===========================
   LAYOUT
   =========================== */
.container{max-width:1280px;margin:0 auto;padding:0 2rem}
section{padding:5rem 0}
.section-title{font-family:var(--font-head);font-size:clamp(1.8rem,3vw,2.4rem);color:var(--text-dark);margin-bottom:.5rem}
.section-sub{font-size:1.05rem;color:var(--text-soft);margin-bottom:2.5rem;max-width:560px}

/* ===========================
   BUTTONS
   =========================== */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:50px;font-weight:600;font-size:.95rem;transition:var(--t);cursor:pointer;border:2px solid transparent;white-space:nowrap}
.btn-primary{background:var(--primary);color:white;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 20px var(--primary-glow)}
.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:white;transform:translateY(-1px)}
.btn-white{background:white;color:var(--primary);border-color:white}
.btn-white:hover{background:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.btn-sm{padding:.5rem 1.2rem;font-size:.875rem}
.btn-lg{padding:1rem 2.5rem;font-size:1.05rem}

/* ===========================
   HEADER / NAV
   =========================== */
#site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:var(--t)}
#site-header.scrolled{box-shadow:var(--shadow-md);border-bottom-color:var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:1rem}
.site-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.site-logo img{height:48px;width:auto}
.logo-name{font-family:var(--font-head);font-size:1.2rem;font-weight:700;color:var(--text-dark);line-height:1.1}
.logo-name span{color:var(--primary);display:block;font-size:.75rem;font-family:var(--font-body);font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.main-nav{display:flex;align-items:center;gap:.1rem}
.main-nav a{padding:.5rem .9rem;border-radius:var(--radius-sm);font-weight:500;font-size:.9rem;color:var(--text-mid);transition:var(--t)}
.main-nav a:hover,.main-nav a.active{color:var(--primary);background:var(--accent)}
.nav-actions{display:flex;align-items:center;gap:.6rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.nav-toggle span{width:24px;height:2px;background:var(--text-dark);border-radius:2px;transition:var(--t)}

/* ===========================
   HERO
   =========================== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0d2818 0%,#1a4a2e 50%,#2d6b45 100%);z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.35;mix-blend-mode:luminosity}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,30,18,.6) 0%,rgba(10,30,18,.45) 50%,rgba(10,30,18,.78) 100%);z-index:1}
.hero-content{position:relative;z-index:2;width:100%;padding-top:5rem}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.13);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);color:white;padding:.4rem 1rem;border-radius:50px;font-size:.82rem;font-weight:600;margin-bottom:1.5rem;letter-spacing:.3px}
.hero-badge em{color:#7EE8A2;font-style:normal}
.hero h1{color:white;margin-bottom:1.25rem;text-shadow:0 2px 20px rgba(0,0,0,.3);max-width:680px}
.hero h1 em{font-style:normal;color:#7EE8A2}
.hero-sub{font-size:1.15rem;color:rgba(255,255,255,.82);margin-bottom:2.5rem;max-width:520px;line-height:1.65}
.hero-stats{display:flex;gap:2.5rem;margin-top:2rem}
.hero-stat{color:white}
.hero-stat strong{display:block;font-size:1.6rem;font-family:var(--font-head);color:#7EE8A2}
.hero-stat span{font-size:.82rem;opacity:.75}

/* Search box */
.search-box{background:white;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:0 20px 60px rgba(0,0,0,.28);max-width:880px;margin-top:2.5rem}
.search-grid{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:.75rem;align-items:end}
.sf{display:flex;flex-direction:column;gap:.3rem}
.sf label{font-size:.75rem;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.5px}
.sf input,.sf select{padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.92rem;color:var(--text-dark);background:var(--bg-light);transition:var(--t);outline:none}
.sf input:focus,.sf select:focus{border-color:var(--primary);background:white;box-shadow:0 0 0 3px var(--primary-glow)}
.search-btn{padding:.7rem 1.5rem;background:var(--primary);color:white;border:none;border-radius:var(--radius-sm);font-weight:700;font-size:.95rem;cursor:pointer;transition:var(--t);display:flex;align-items:center;gap:.5rem;white-space:nowrap}
.search-btn:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px var(--primary-glow)}

/* ===========================
   CARDS
   =========================== */
.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.place-card{background:white;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:var(--t);position:relative}
.place-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-green);border-color:transparent}
.card-img{position:relative;height:196px;overflow:hidden;background:var(--bg-grey)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.place-card:hover .card-img img{transform:scale(1.07)}
.card-badge{position:absolute;top:.7rem;left:.7rem;background:white;color:var(--primary);font-size:.72rem;font-weight:700;padding:.28rem .65rem;border-radius:50px;display:flex;align-items:center;gap:.3rem}
.card-fav{position:absolute;top:.7rem;right:.7rem;width:32px;height:32px;background:white;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--t);box-shadow:var(--shadow-sm);border:none;font-size:.95rem;color:var(--text-soft)}
.card-fav:hover,.card-fav.active{color:#E53E3E}
.card-gf{position:absolute;bottom:.7rem;left:.7rem;background:var(--primary);color:white;font-size:.68rem;font-weight:700;padding:.22rem .55rem;border-radius:4px;letter-spacing:.5px}
.card-body{padding:1.2rem}
.card-loc{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-soft);margin-bottom:.35rem}
.card-title{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--text-dark);margin-bottom:.55rem;line-height:1.3}
.card-rating{display:flex;align-items:center;gap:.45rem;margin-bottom:.9rem}
.stars{display:flex;gap:1px}
.stars span{color:var(--gold);font-size:.82rem}
.stars span.e{color:var(--border)}
.rating-score{font-weight:700;font-size:.88rem;color:var(--text-dark)}
.rating-count{font-size:.78rem;color:var(--text-soft)}
.card-footer{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.2rem;border-top:1px solid var(--bg-grey)}

/* ===========================
   MAP
   =========================== */
.map-section{background:var(--bg-light)}
.map-filters{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}
.mfbtn{padding:.48rem 1.2rem;border-radius:50px;border:1.5px solid var(--border);background:white;color:var(--text-mid);font-weight:600;font-size:.85rem;cursor:pointer;transition:var(--t);display:flex;align-items:center;gap:.4rem}
.mfbtn:hover,.mfbtn.active{background:var(--primary);border-color:var(--primary);color:white}
#map-container{width:100%;height:500px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border)}

/* ===========================
   CTA STRIPS
   =========================== */
.cta-strip{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);padding:4rem 0;position:relative;overflow:hidden}
.cta-strip::before{content:'';position:absolute;top:-50%;right:-10%;width:500px;height:500px;background:rgba(255,255,255,.04);border-radius:50%}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.cta-text h2{color:white;margin-bottom:.5rem}
.cta-text p{color:rgba(255,255,255,.78);font-size:1.02rem}
.cta-actions{display:flex;gap:1rem;flex-wrap:wrap}
.fav-strip{background:var(--accent);border-top:1px solid rgba(46,125,82,.1);border-bottom:1px solid rgba(46,125,82,.1);padding:3.5rem 0}
.fav-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.fav-icon-wrap{width:58px;height:58px;background:var(--primary);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:white;flex-shrink:0}

/* ===========================
   BLOG
   =========================== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.blog-card{background:white;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);transition:var(--t)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.blog-img{height:196px;overflow:hidden;background:var(--bg-grey)}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.blog-card:hover .blog-img img{transform:scale(1.05)}
.blog-body{padding:1.4rem}
.blog-cat{font-size:.72rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:.45rem}
.blog-title{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--text-dark);margin-bottom:.7rem;line-height:1.4}
.blog-title:hover{color:var(--primary)}
.blog-meta{display:flex;align-items:center;gap:.7rem;font-size:.8rem;color:var(--text-soft)}

/* ===========================
   PARTNERS / FOOTER
   =========================== */
.partners-bar{background:var(--bg-light);padding:2.5rem 0;border-top:1px solid var(--border)}
.partners-label{text-align:center;font-size:.8rem;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:1px;margin-bottom:1.4rem}
.partners-logos{display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap}
.partner-logo{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.4rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-weight:700;font-size:.95rem;color:var(--text-mid);background:white;transition:var(--t)}
.partner-logo:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
#site-footer{background:var(--text-dark);color:rgba(255,255,255,.8);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand p{font-size:.88rem;line-height:1.7;color:rgba(255,255,255,.55);max-width:280px;margin-top:.75rem}
.footer-logo{display:flex;align-items:center;gap:.65rem;text-decoration:none}
.footer-logo img{height:40px;width:auto;filter:brightness(0) invert(1) opacity(.8)}
.footer-logo-name{font-family:var(--font-head);font-size:1.1rem;color:white;font-weight:700}
.footer-logo-name span{color:#7EE8A2;display:block;font-size:.7rem;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.5px}
.footer-col h4{font-family:var(--font-head);font-size:.95rem;color:white;margin-bottom:1.2rem}
.footer-col ul{display:flex;flex-direction:column;gap:.45rem}
.footer-col ul li a{font-size:.875rem;color:rgba(255,255,255,.55);transition:var(--t)}
.footer-col ul li a:hover{color:#7EE8A2}
.footer-bottom{border-top:1px solid rgba(255,255,255,.09);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;font-size:.82rem;color:rgba(255,255,255,.35)}
.footer-social{display:flex;gap:.6rem}
.footer-social a{width:34px;height:34px;background:rgba(255,255,255,.07);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);transition:var(--t);font-size:.85rem}
.footer-social a:hover{background:var(--primary);color:white}

/* ===========================
   SINGLE PLACE
   =========================== */
.place-detail{padding-top:88px}
.place-gallery{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:320px 180px;gap:.5rem;border-radius:var(--radius);overflow:hidden}
.gallery-main{grid-row:1/3;overflow:hidden}
.gallery-main img,.gallery-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-main:hover img,.gallery-thumb:hover img{transform:scale(1.04)}
.gallery-thumb{overflow:hidden;position:relative}
.gallery-more{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;color:white;font-weight:700;font-size:1.1rem;cursor:pointer}
.place-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem;margin-top:2rem}
.booking-card{background:white;border:1.5px solid var(--border);border-radius:var(--radius);padding:1.5rem;position:sticky;top:90px;box-shadow:var(--shadow-md)}
.rating-big{font-family:var(--font-head);font-size:2.8rem;color:var(--text-dark);line-height:1;display:flex;align-items:baseline;gap:.5rem;margin-bottom:.25rem}
.rating-big span{font-size:1rem;font-weight:400;color:var(--text-soft)}
.partner-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.82rem;border-radius:var(--radius-sm);font-weight:700;font-size:.92rem;transition:var(--t);cursor:pointer;border:2px solid transparent;text-decoration:none}
.pb-booking{background:#003580;color:white}
.pb-booking:hover{background:#00266A}
.pb-airbnb{background:#FF385C;color:white}
.pb-airbnb:hover{background:#E31C5F}
.pb-web{background:white;color:var(--primary);border-color:var(--primary)}
.pb-web:hover{background:var(--accent)}
.gf-tag{background:var(--accent);color:var(--primary);border:1px solid rgba(46,125,82,.2);padding:.28rem .7rem;border-radius:50px;font-size:.78rem;font-weight:600}
.review-card{background:var(--bg-light);border-radius:var(--radius-sm);padding:1.2rem;margin-bottom:.9rem;border:1px solid var(--border)}
.reviewer-av{width:40px;height:40px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:white;font-weight:700;font-size:.95rem}

/* ===========================
   AUTH (LOGIN / REGISTER)
   =========================== */
.auth-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
.auth-left{position:relative;background:linear-gradient(160deg,#0d2818 0%,#1a4a2e 45%,#2d6b45 100%);display:flex;flex-direction:column;justify-content:space-between;padding:3rem;overflow:hidden}
.auth-left::before{content:'';position:absolute;top:-100px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(46,125,82,.3) 0%,transparent 70%);border-radius:50%}
.auth-left::after{content:'';position:absolute;bottom:-80px;left:-80px;width:400px;height:400px;background:radial-gradient(circle,rgba(126,232,162,.1) 0%,transparent 70%);border-radius:50%}
.auth-left-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;position:relative;z-index:1}
.auth-left-logo img{height:52px;width:auto}
.auth-left-logo-name{font-family:var(--font-head);font-size:1.25rem;color:white;font-weight:700;line-height:1.1}
.auth-left-logo-name span{color:#7EE8A2;display:block;font-size:.72rem;font-family:var(--font-body);letter-spacing:.5px;text-transform:uppercase}
.auth-left-content{position:relative;z-index:1}
.auth-left-content h2{font-family:var(--font-head);font-size:clamp(1.8rem,3vw,2.6rem);color:white;line-height:1.25;margin-bottom:1.1rem}
.auth-left-content h2 em{font-style:normal;color:#7EE8A2}
.auth-left-content p{color:rgba(255,255,255,.68);font-size:1rem;line-height:1.75;max-width:360px;margin-bottom:2rem}
.auth-features{display:flex;flex-direction:column;gap:.9rem}
.auth-feat{display:flex;align-items:center;gap:1rem;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.9rem 1.1rem;backdrop-filter:blur(8px);transition:var(--t)}
.auth-feat:hover{background:rgba(255,255,255,.12);transform:translateX(4px)}
.auth-feat-icon{width:38px;height:38px;background:rgba(126,232,162,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.auth-feat-text strong{display:block;color:white;font-size:.875rem;font-weight:600}
.auth-feat-text span{color:rgba(255,255,255,.5);font-size:.78rem}
.auth-left-stats{position:relative;z-index:1;display:flex;gap:2rem}
.auth-stat strong{display:block;font-family:var(--font-head);font-size:1.5rem;color:#7EE8A2}
.auth-stat span{font-size:.75rem;color:rgba(255,255,255,.45)}
.auth-right{display:flex;align-items:center;justify-content:center;padding:2rem;background:white}
.auth-box{width:100%;max-width:440px}
.auth-tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--bg-light);border-radius:12px;padding:4px;margin-bottom:2rem}
.auth-tab{padding:.62rem;text-align:center;font-weight:600;font-size:.88rem;color:var(--text-soft);border-radius:9px;cursor:pointer;transition:var(--t);text-decoration:none;border:none;background:none;font-family:inherit}
.auth-tab.active{background:white;color:var(--primary);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.auth-title{font-family:var(--font-head);font-size:1.8rem;font-weight:700;color:var(--text-dark);margin-bottom:.35rem}
.auth-sub{color:var(--text-soft);font-size:.9rem;margin-bottom:1.75rem}
.social-btns{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.4rem}
.social-btn{display:flex;align-items:center;justify-content:center;gap:.7rem;padding:.75rem 1.25rem;border-radius:10px;font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--t);text-decoration:none;font-family:inherit;border:1.5px solid var(--border);background:white;color:var(--text-dark);width:100%}
.social-btn:hover{border-color:#CBD5E0;background:var(--bg-light);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.social-btn svg{width:20px;height:20px;flex-shrink:0}
.divider-or{display:flex;align-items:center;gap:1rem;margin-bottom:1.4rem;color:var(--text-soft);font-size:.78rem;font-weight:600}
.divider-or::before,.divider-or::after{content:'';flex:1;height:1px;background:var(--border)}
.fg{margin-bottom:1rem}
.fg label{display:block;font-size:.8rem;font-weight:700;color:var(--text-mid);margin-bottom:.38rem;letter-spacing:.2px}
.fg .iw{position:relative}
.fg .ii{position:absolute;left:.88rem;top:50%;transform:translateY(-50%);color:var(--text-soft);font-size:.9rem;pointer-events:none}
.fg input{width:100%;padding:.75rem 1rem .75rem 2.5rem;border:1.5px solid var(--border);border-radius:10px;font-size:.92rem;color:var(--text-dark);background:var(--bg-light);font-family:inherit;transition:var(--t);outline:none}
.fg input:focus{border-color:var(--primary);background:white;box-shadow:0 0 0 3px var(--primary-glow)}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.tpass{position:absolute;right:.88rem;top:50%;transform:translateY(-50%);cursor:pointer;color:var(--text-soft);font-size:.9rem;background:none;border:none;padding:0;line-height:1}
.tpass:hover{color:var(--text-dark)}
.forgot-lnk{font-size:.8rem;color:var(--primary);text-decoration:none;font-weight:500;float:right;margin-top:-.8rem;margin-bottom:.8rem;display:block}
.forgot-lnk:hover{text-decoration:underline}
.submit-btn{width:100%;padding:.88rem;background:var(--primary);color:white;border:none;border-radius:10px;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;transition:var(--t);margin-top:.5rem;position:relative;overflow:hidden}
.submit-btn:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 20px var(--primary-glow)}
.terms-note{font-size:.76rem;color:var(--text-soft);text-align:center;margin-top:1rem;line-height:1.6}
.terms-note a{color:var(--primary);text-decoration:none}
.alert{padding:.82rem 1rem;border-radius:10px;font-size:.875rem;font-weight:500;margin-bottom:1.2rem;display:flex;align-items:center;gap:.6rem}
.alert-err{background:#FFF5F5;border:1px solid #FC8181;color:#C53030}
.alert-ok{background:var(--accent);border:1px solid rgba(46,125,82,.3);color:var(--primary-dark)}
.sm-bars{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-top:5px}
.sm-bar{height:3px;background:var(--border);border-radius:2px;transition:background .3s}
.sm-label{font-size:.7rem;color:var(--text-soft);margin-top:4px}
.tab-panel{display:none}
.tab-panel.active{display:block;animation:fadeUp .3s ease forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.remember-row{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.remember-row input{accent-color:var(--primary);width:15px;height:15px}
.remember-row label{font-size:.85rem;color:var(--text-mid);cursor:pointer}

/* ===========================
   SUBMIT FORM
   =========================== */
.form-section{background:var(--bg-light)}
.form-card{background:white;border-radius:var(--radius);padding:2.5rem;box-shadow:var(--shadow-md);border:1px solid var(--border);max-width:860px;margin:0 auto}
.form-group{margin-bottom:1.15rem}
.form-group label{display:block;font-weight:600;font-size:.875rem;color:var(--text-dark);margin-bottom:.38rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.72rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.93rem;color:var(--text-dark);background:var(--bg-light);transition:var(--t);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);background:white;box-shadow:0 0 0 3px var(--primary-glow)}
.form-group textarea{resize:vertical;min-height:110px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-note{font-size:.78rem;color:var(--text-soft);margin-top:.25rem}
.form-section-title{font-family:var(--font-head);font-size:1.1rem;color:var(--primary);margin:1.75rem 0 1rem;display:flex;align-items:center;gap:.5rem}

/* Survey */
.survey-box{background:var(--accent);border:1.5px solid rgba(46,125,82,.25);border-radius:var(--radius);padding:2rem;margin-top:1.5rem;display:none}
.survey-box.visible{display:block;animation:fadeUp .35s ease}
.survey-q{margin-bottom:1.5rem}
.survey-q-title{font-weight:700;font-size:.95rem;color:var(--text-dark);margin-bottom:.75rem;line-height:1.5}
.survey-q-title span{color:var(--primary)}
.survey-option{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.45rem;cursor:pointer;font-size:.875rem;color:var(--text-mid);line-height:1.4}
.survey-option input{accent-color:var(--primary);margin-top:2px;flex-shrink:0;width:15px;height:15px}
.survey-option:hover{color:var(--text-dark)}
.survey-sub{margin-left:1.5rem;margin-top:.3rem}
.survey-sub-title{font-size:.8rem;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.4px;margin-bottom:.35rem;margin-top:.5rem}
.star-scale{display:flex;gap:.6rem;margin-top:.5rem}
.star-scale-btn{width:40px;height:40px;border:1.5px solid var(--border);border-radius:8px;background:white;font-weight:700;font-size:.95rem;cursor:pointer;transition:var(--t);color:var(--text-mid)}
.star-scale-btn:hover,.star-scale-btn.selected{background:var(--primary);border-color:var(--primary);color:white}
.other-input{margin-top:.4rem;width:100%;padding:.5rem .75rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;outline:none;transition:var(--t)}
.other-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.admin-toggle-row{background:var(--accent);border:1.5px solid rgba(46,125,82,.2);border-radius:var(--radius-sm);padding:1rem 1.25rem;display:flex;align-items:center;gap:.85rem;cursor:pointer;transition:var(--t)}
.admin-toggle-row:hover{border-color:var(--primary);background:white}
.admin-toggle-row input{accent-color:var(--primary);width:18px;height:18px;flex-shrink:0}
.admin-toggle-label{font-weight:600;font-size:.95rem;color:var(--text-dark)}
.admin-toggle-label span{display:block;font-size:.8rem;font-weight:400;color:var(--text-soft);margin-top:.2rem}

/* ===========================
   DASHBOARD
   =========================== */
.dashboard{padding-top:88px}
.dash-layout{display:grid;grid-template-columns:250px 1fr;gap:2rem;align-items:start}
.dash-sidebar{background:white;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;position:sticky;top:88px}
.dash-avatar{width:62px;height:62px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:white;font-size:1.5rem;margin-bottom:.7rem}
.dash-nav{margin-top:1.4rem}
.dash-nav a{display:flex;align-items:center;gap:.7rem;padding:.62rem .7rem;border-radius:var(--radius-sm);font-weight:500;font-size:.88rem;color:var(--text-mid);margin-bottom:.2rem;transition:var(--t)}
.dash-nav a:hover,.dash-nav a.active{background:var(--accent);color:var(--primary)}
.dash-card{background:white;border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;margin-bottom:1.5rem}
.dash-card h3{margin-bottom:1.25rem;color:var(--text-dark)}

/* ===========================
   NOTIFICATIONS
   =========================== */
.gfh-toast{position:fixed;bottom:2rem;right:2rem;background:var(--primary);color:white;padding:.9rem 1.4rem;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:9999;font-weight:500;font-size:.9rem;transform:translateX(120%);transition:transform .3s ease;display:flex;align-items:center;gap:.5rem}
.gfh-toast.show{transform:translateX(0)}
.gfh-toast.err{background:#E53E3E}

/* ===========================
   FORMS GENERAL
   =========================== */
.page-hero{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);padding:3rem 0;color:white}
.page-hero h1{color:white;margin-bottom:.4rem}
.page-hero p{color:rgba(255,255,255,.78);margin:0}

/* ===========================
   RESPONSIVE
   =========================== */
@media(max-width:1200px){.cards-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:992px){.search-grid{grid-template-columns:1fr 1fr}.cards-grid{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}.place-grid{grid-template-columns:1fr}.booking-card{position:static}.dash-layout{grid-template-columns:1fr}.auth-page{grid-template-columns:1fr}.auth-left{display:none}}
@media(max-width:768px){.main-nav{display:none}.main-nav.open{display:flex;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:white;padding:1rem;box-shadow:var(--shadow-md);border-top:1px solid var(--border)}.nav-toggle{display:flex}.search-grid{grid-template-columns:1fr}.cards-grid{grid-template-columns:1fr}.blog-grid{grid-template-columns:1fr}.cta-inner,.fav-inner{flex-direction:column;text-align:center}.footer-grid{grid-template-columns:1fr}.form-row,.fg-row{grid-template-columns:1fr}.place-gallery{grid-template-columns:1fr;grid-template-rows:280px}.place-gallery>*:not(.gallery-main){display:none}}
@media(max-width:480px){.container{padding:0 1rem}section{padding:3rem 0}}
