:root {
  --bg:#ffffff; --surface:#f7f7f7; --border:#e8e8e8; --muted:#717171;
  --dark:#111111; --accent:#1a6b45; --accent-lt:#eaf4ee;
  --radius-sm:10px; --radius-md:16px; --radius-lg:24px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);
  --shadow-lg:0 12px 40px rgba(0,0,0,.12);
  --transition:all 0.22s cubic-bezier(.4,0,.2,1);
  --font-body:'DM Sans',sans-serif;
  --font-display:'Playfair Display',serif;
  --max-w:1200px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--bg);color:var(--dark);line-height:1.5;-webkit-font-smoothing:antialiased;}
img{display:block;max-width:100%;}
a{text-decoration:none;color:inherit;}
button{font-family:inherit;cursor:pointer;border:none;outline:none;}
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px;}
.section{padding:72px 0;}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:32px;}
.section-title{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.1rem);font-weight:500;letter-spacing:-0.5px;line-height:1.2;}
.section-sub{font-size:0.9rem;color:var(--muted);margin-top:6px;}
.section-link{font-size:0.88rem;font-weight:600;color:var(--dark);text-decoration:underline;text-underline-offset:3px;white-space:nowrap;transition:var(--transition);}
.section-link:hover{color:var(--accent);}
.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,0.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:var(--transition);}
.header-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px;height:72px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.logo{font-family:var(--font-display);font-weight:600;font-size:1.5rem;color:var(--dark);letter-spacing:-0.5px;flex-shrink:0;}
.logo span{color:var(--accent);}
.header-search{flex:1;max-width:420px;background:var(--bg);border:1.5px solid var(--border);border-radius:50px;padding:10px 16px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm);}
.header-search:hover{box-shadow:var(--shadow-md);border-color:#ccc;}
.header-search-divider{width:1px;height:20px;background:var(--border);}
.header-search-item{flex:1;min-width:0;}
.header-search-item label{display:block;font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--dark);white-space:nowrap;}
.header-search-item span{font-size:0.82rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;}
.header-search-btn{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition);}
.header-search-btn:hover{background:#155737;}
.header-search-btn svg{width:15px;height:15px;}
.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.nav-link{font-size:0.88rem;font-weight:500;color:var(--dark);padding:8px 14px;border-radius:50px;transition:var(--transition);}
.nav-link:hover{background:var(--surface);}
.user-btn{display:flex;align-items:center;gap:10px;background:var(--bg);border:1.5px solid var(--border);border-radius:50px;padding:6px 6px 6px 14px;transition:var(--transition);box-shadow:var(--shadow-sm);}
.user-btn:hover{box-shadow:var(--shadow-md);}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--dark);display:flex;align-items:center;justify-content:center;}
.user-avatar svg{width:18px;height:18px;fill:#fff;}
.hamburger-btn{display:none;width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border);background:var(--bg);align-items:center;justify-content:center;cursor:pointer;}
.hamburger-btn svg{width:18px;height:18px;}
.footer{border-top:1px solid var(--border);padding:48px 0 32px;}
.footer-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px;}
.footer-brand .logo{font-size:1.3rem;margin-bottom:12px;}
.footer-brand p{font-size:0.85rem;color:var(--muted);line-height:1.65;max-width:220px;}
.footer-social{display:flex;gap:10px;margin-top:20px;}
.social-icon{width:36px;height:36px;border:1.5px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition);color:var(--muted);}
.social-icon:hover{border-color:var(--dark);color:var(--dark);}
.social-icon svg{width:15px;height:15px;}
.footer-col h4{font-size:0.8rem;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;margin-bottom:16px;}
.footer-col a{display:block;font-size:0.87rem;color:var(--muted);margin-bottom:10px;transition:var(--transition);}
.footer-col a:hover{color:var(--dark);}
.footer-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:center;}
.footer-bottom p{font-size:0.82rem;color:var(--muted);}
.footer-legal{display:flex;gap:20px;}
.footer-legal a{font-size:0.82rem;color:var(--muted);transition:var(--transition);}
.footer-legal a:hover{color:var(--dark);}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity 0.25s ease;}
.modal-overlay.open{opacity:1;pointer-events:auto;}
.modal{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:460px;padding:40px;position:relative;transform:translateY(16px);transition:transform 0.25s ease;box-shadow:var(--shadow-lg);}
.modal-overlay.open .modal{transform:translateY(0);}
.modal-close{position:absolute;top:20px;right:20px;width:32px;height:32px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);}
.modal-close:hover{background:var(--border);}
.modal-close svg{width:16px;height:16px;}
.modal-logo{font-family:var(--font-display);font-weight:600;font-size:1.3rem;margin-bottom:24px;}
.modal-logo span{color:var(--accent);}
.auth-tabs{display:flex;background:var(--surface);border-radius:var(--radius-sm);padding:4px;margin-bottom:24px;}
.auth-tab{flex:1;padding:9px;border-radius:8px;font-size:0.88rem;font-weight:600;text-align:center;cursor:pointer;color:var(--muted);transition:var(--transition);}
.auth-tab.active{background:#fff;color:var(--dark);box-shadow:var(--shadow-sm);}
.form-group{margin-bottom:16px;}
.form-group label{display:block;font-size:0.82rem;font-weight:600;margin-bottom:6px;}
.form-group input{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.92rem;color:var(--dark);outline:none;transition:var(--transition);}
.form-group input:focus{border-color:var(--dark);}
.form-group input::placeholder{color:var(--muted);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.btn-full{width:100%;padding:14px;border-radius:var(--radius-sm);font-weight:700;font-size:0.95rem;transition:var(--transition);}
.btn-dark{background:var(--dark);color:#fff;}
.btn-dark:hover{background:#2a2a2a;}
.divider{display:flex;align-items:center;gap:12px;margin:20px 0;font-size:0.8rem;color:var(--muted);}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border);}
.btn-google{width:100%;padding:12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-size:0.9rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px;transition:var(--transition);margin-bottom:12px;}
.btn-google:hover{background:var(--surface);}
.btn-guest{width:100%;padding:12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-size:0.88rem;font-weight:600;color:var(--muted);transition:var(--transition);}
.btn-guest:hover{background:var(--surface);color:var(--dark);}
.auth-footer{text-align:center;margin-top:20px;font-size:0.83rem;color:var(--muted);}
.auth-footer a{color:var(--dark);font-weight:600;text-decoration:underline;text-underline-offset:2px;}
.auth-choice-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.55);backdrop-filter:blur(6px);z-index:3000;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity 0.25s ease;}
.auth-choice-overlay.open{opacity:1;pointer-events:auto;}
.auth-choice-modal{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:400px;padding:44px 36px;text-align:center;transform:translateY(16px);transition:transform 0.25s ease;box-shadow:0 24px 60px rgba(0,0,0,0.18);}
.auth-choice-overlay.open .auth-choice-modal{transform:translateY(0);}
.auth-choice-icon{width:60px;height:60px;background:var(--accent-lt);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;}
.auth-choice-icon svg{width:28px;height:28px;stroke:var(--accent);}
.auth-choice-modal h2{font-size:1.45rem;font-weight:800;margin-bottom:8px;letter-spacing:-0.4px;}
.auth-choice-modal p{font-size:0.9rem;color:var(--muted);margin-bottom:32px;line-height:1.6;}
.auth-choice-btn{display:block;width:100%;padding:18px;border-radius:var(--radius-md);font-size:1rem;font-weight:800;cursor:pointer;transition:var(--transition);margin-bottom:12px;border:none;font-family:var(--font-body);letter-spacing:-0.2px;}
.auth-choice-btn.primary{background:var(--dark);color:#fff;}
.auth-choice-btn.primary:hover{background:#222;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.18);}
.auth-choice-btn.secondary{background:#fff;color:var(--dark);border:2px solid var(--dark);}
.auth-choice-btn.secondary:hover{background:var(--surface);transform:translateY(-2px);}
.auth-choice-dismiss{margin-top:4px;font-size:0.82rem;color:var(--muted);cursor:pointer;background:none;border:none;font-family:var(--font-body);text-decoration:underline;text-underline-offset:2px;}
.auth-choice-dismiss:hover{color:var(--dark);}
.mobile-drawer{display:none;position:fixed;inset:0;z-index:3000;}
.drawer-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.4);}
.drawer-panel{position:absolute;top:0;right:0;bottom:0;width:280px;background:#fff;padding:24px;display:flex;flex-direction:column;gap:8px;transform:translateX(100%);transition:transform 0.3s ease;overflow-y:auto;}
.mobile-drawer.open{display:block;}
.mobile-drawer.open .drawer-panel{transform:translateX(0);}
.drawer-close{align-self:flex-end;width:36px;height:36px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;margin-bottom:8px;}
.drawer-close svg{width:18px;height:18px;}
.drawer-link{display:block;padding:14px 0;border-bottom:1px solid var(--border);font-weight:500;font-size:1rem;}
.drawer-actions{margin-top:24px;display:flex;flex-direction:column;gap:10px;}
.drawer-btn{width:100%;padding:13px;border-radius:var(--radius-sm);font-weight:600;font-size:0.95rem;text-align:center;}
.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-md);height:260px;}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){
  .header-search{display:none;}.nav-link{display:none;}.header-inner{padding:0 16px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center;}
  .section{padding:48px 0;}
  .hamburger-btn{display:flex !important;}
  .form-row{grid-template-columns:1fr;}
}
