/* ============================================================
   YogaKeşfet - Premium Arayüz v2.0
   Luxury Organic Design System
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500&family=Outfit:wght@300;400;500;600;700&display=swap');

:root {
    --sage: #7C9885; --sage-light: #A8C5B2; --sage-dark: #5A7563; --sage-50: #f0f5f2; --sage-100: #dce8e0; --sage-900: #2d3e33;
    --earth: #8B7355; --earth-light: #C4A882; --earth-dark: #6B5740;
    --sand: #E8DDD3; --sand-light: #F5F0EB; --sand-dark: #D4C4B4;
    --terracotta: #C17F59; --terracotta-light: #D4A07E;
    --cream: #FAF8F5; --warm-white: #FEFDFB; --off-white: #F7F4F0; --deep: #1a1a1a;
    --text-primary: #1E1E1E; --text-secondary: #4A4A4A; --text-muted: #8A8A8A; --text-light: #B5B5B5;
    --gold: #C9A96E; --gold-light: #E4D5B0; --rose: #C4908A; --lavender: #9B8EC2;
    --success: #6B9E7A; --warning: #D4A74A; --error: #C27070; --info: #7B9EC2;
    --font-display: 'Playfair Display', Georgia, serif;
    --font-body: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;
    --header-height: 76px; --container-max: 1280px; --container-narrow: 800px;
    --radius: 16px; --radius-sm: 10px; --radius-lg: 24px; --radius-xl: 32px;
    --shadow-xs: 0 1px 2px rgba(0,0,0,0.04);
    --shadow-sm: 0 2px 8px rgba(0,0,0,0.04), 0 1px 2px rgba(0,0,0,0.03);
    --shadow: 0 4px 16px rgba(0,0,0,0.06), 0 2px 4px rgba(0,0,0,0.03);
    --shadow-md: 0 8px 32px rgba(0,0,0,0.08), 0 4px 8px rgba(0,0,0,0.04);
    --shadow-lg: 0 20px 60px rgba(0,0,0,0.1), 0 8px 16px rgba(0,0,0,0.05);
    --shadow-xl: 0 32px 80px rgba(0,0,0,0.12), 0 16px 32px rgba(0,0,0,0.06);
    --shadow-glow: 0 0 40px rgba(124,152,133,0.15);
    --shadow-card-hover: 0 24px 48px rgba(0,0,0,0.12), 0 0 0 1px rgba(124,152,133,0.1);
    --ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
    --ease-spring: cubic-bezier(0.175, 0.885, 0.32, 1.275);
    --transition: all 0.4s var(--ease-out);
    --transition-fast: all 0.2s var(--ease);
    --transition-slow: all 0.6s var(--ease-out);
    --glass-bg: rgba(255,255,255,0.7); --glass-border: rgba(255,255,255,0.3); --glass-blur: blur(20px);
}

*, *::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-primary); background: var(--cream); line-height: 1.7; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: var(--transition-fast); }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, select, textarea { font-family: inherit; font-size: 1rem; }
h1,h2,h3,h4,h5,h6 { font-family: var(--font-display); font-weight: 600; line-height: 1.2; color: var(--text-primary); }
.container { max-width: var(--container-max); margin: 0 auto; padding: 0 28px; }
.section { padding: 100px 0; }
.section-alt { background: white; }
.prose { max-width: var(--container-narrow); }
.prose p { margin-bottom: 1.2em; }
.full-width { grid-column: 1 / -1; }

/* Custom Cursor */
.cursor-dot { position:fixed;width:8px;height:8px;background:var(--sage);border-radius:50%;pointer-events:none;z-index:99999;mix-blend-mode:difference;transition:transform 0.1s;transform:translate(-50%,-50%); }
.cursor-ring { position:fixed;width:40px;height:40px;border:2px solid rgba(124,152,133,0.3);border-radius:50%;pointer-events:none;z-index:99998;transition:all 0.15s var(--ease-out);transform:translate(-50%,-50%); }
.cursor-ring.hover { width:60px;height:60px;border-color:var(--sage);background:rgba(124,152,133,0.06); }

/* Reveal Animations */
.reveal { opacity:0; transform:translateY(40px); transition:opacity 0.8s var(--ease-out),transform 0.8s var(--ease-out); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-left { opacity:0; transform:translateX(-60px); transition:opacity 0.8s var(--ease-out),transform 0.8s var(--ease-out); }
.reveal-left.visible { opacity:1; transform:translateX(0); }
.reveal-right { opacity:0; transform:translateX(60px); transition:opacity 0.8s var(--ease-out),transform 0.8s var(--ease-out); }
.reveal-right.visible { opacity:1; transform:translateX(0); }
.reveal-scale { opacity:0; transform:scale(0.9); transition:opacity 0.8s var(--ease-out),transform 0.8s var(--ease-out); }
.reveal-scale.visible { opacity:1; transform:scale(1); }
.stagger-1{transition-delay:.05s}.stagger-2{transition-delay:.1s}.stagger-3{transition-delay:.15s}.stagger-4{transition-delay:.2s}.stagger-5{transition-delay:.25s}.stagger-6{transition-delay:.3s}

/* Buttons */
.btn { display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 32px;border-radius:60px;font-weight:600;font-size:0.92rem;letter-spacing:0.02em;transition:var(--transition);white-space:nowrap;position:relative;overflow:hidden; }
.btn::before { content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.2),transparent);opacity:0;transition:opacity 0.3s; }
.btn:hover::before { opacity:1; }
.btn-primary { background:linear-gradient(135deg,var(--sage),var(--sage-dark));color:white;box-shadow:0 4px 16px rgba(124,152,133,0.3); }
.btn-primary:hover { transform:translateY(-2px);box-shadow:0 8px 32px rgba(124,152,133,0.4); }
.btn-outline { border:2px solid var(--sage);color:var(--sage-dark);background:transparent; }
.btn-outline:hover { background:var(--sage);color:white;transform:translateY(-2px);box-shadow:0 8px 24px rgba(124,152,133,0.3); }
.btn-white { background:white;color:var(--sage-dark);box-shadow:var(--shadow); }
.btn-white:hover { transform:translateY(-2px);box-shadow:var(--shadow-md); }
.btn-glass { background:var(--glass-bg);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);color:var(--text-primary); }
.btn-block { width:100%; }
.btn-sm { padding:10px 22px;font-size:0.85rem; }
.btn-lg { padding:18px 42px;font-size:1.05rem; }

/* Header */
.site-header { position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--header-height);transition:var(--transition); }
.site-header::before { content:'';position:absolute;inset:0;background:rgba(250,248,245,0.85);backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border-bottom:1px solid rgba(0,0,0,0.04);transition:var(--transition); }
.site-header.scrolled::before { background:rgba(250,248,245,0.95);box-shadow:0 1px 30px rgba(0,0,0,0.06); }
.header-inner { position:relative;max-width:var(--container-max);margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:100%; }
.logo { display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1.5rem;color:var(--text-primary);letter-spacing:-0.03em; }
.logo-icon { width:36px;height:36px;background:linear-gradient(135deg,var(--sage),var(--sage-dark));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:white;box-shadow:0 2px 8px rgba(124,152,133,0.3); }
.logo strong { color:var(--sage-dark); }
.main-nav { display:flex;gap:2px; }
.nav-link { display:flex;align-items:center;gap:6px;padding:10px 18px;border-radius:60px;font-size:0.9rem;font-weight:500;color:var(--text-secondary);position:relative; }
.nav-link::after { content:'';position:absolute;bottom:6px;left:50%;width:0;height:2px;background:var(--sage);border-radius:1px;transition:all 0.3s var(--ease-out);transform:translateX(-50%); }
.nav-link:hover { color:var(--sage-dark); }
.nav-link:hover::after { width:20px; }
.nav-link.active { color:var(--sage);font-weight:600; }
.nav-link.active::after { width:20px; }
.header-actions { display:flex;align-items:center;gap:10px; }
.search-toggle { width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text-secondary); }
.search-toggle:hover { background:var(--sage-50);color:var(--sage);transform:scale(1.05); }
.btn-login { padding:10px 22px;font-weight:500;color:var(--text-secondary);border-radius:60px;font-size:0.88rem; }
.btn-login:hover { color:var(--sage-dark); }
.btn-register { padding:10px 24px;background:linear-gradient(135deg,var(--sage),var(--sage-dark));color:white;border-radius:60px;font-size:0.88rem;font-weight:600;box-shadow:0 2px 12px rgba(124,152,133,0.25); }
.btn-register:hover { transform:translateY(-1px);box-shadow:0 4px 20px rgba(124,152,133,0.35); }
.user-menu-wrap { position:relative; }
.user-menu-btn { display:flex;align-items:center;gap:10px;padding:5px 14px 5px 5px;border-radius:60px;border:1px solid var(--sand-dark);transition:var(--transition-fast); }
.user-menu-btn:hover { border-color:var(--sage-light);box-shadow:var(--shadow-sm); }
.user-avatar { width:34px;height:34px;background:linear-gradient(135deg,var(--sage),var(--sage-dark));color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.85rem; }
.user-name-short { font-size:0.88rem;font-weight:500; }
.user-dropdown { position:absolute;top:calc(100% + 10px);right:0;background:white;border-radius:var(--radius);box-shadow:var(--shadow-xl);min-width:220px;padding:8px;opacity:0;visibility:hidden;transform:translateY(-10px) scale(0.98);transition:var(--transition);border:1px solid rgba(0,0,0,0.04); }
.user-dropdown.active { opacity:1;visibility:visible;transform:translateY(0) scale(1); }
.user-dropdown a { display:block;padding:11px 16px;border-radius:var(--radius-sm);font-size:0.88rem;color:var(--text-secondary); }
.user-dropdown a:hover { background:var(--sage-50);color:var(--sage-dark); }
.user-dropdown hr { border:none;border-top:1px solid var(--sand);margin:4px 0; }
.admin-link { color:var(--sage) !important;font-weight:600 !important; }
.logout-link { color:var(--error) !important; }
.mobile-menu-btn { display:none;flex-direction:column;gap:5px;width:28px;padding:4px 0; }
.mobile-menu-btn span { display:block;height:2px;background:var(--text-primary);border-radius:2px;transition:var(--transition); }
.mobile-menu-btn.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.mobile-menu-btn.active span:nth-child(2){opacity:0}.mobile-menu-btn.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-nav-overlay { position:fixed;inset:0;top:var(--header-height);background:rgba(250,248,245,0.98);backdrop-filter:blur(30px);z-index:999;opacity:0;visibility:hidden;transition:var(--transition); }
.mobile-nav-overlay.active { opacity:1;visibility:visible; }
.mobile-nav-inner { padding:32px 28px;display:flex;flex-direction:column;gap:6px; }
.mobile-nav-inner a { padding:16px 0;font-size:1.3rem;font-weight:500;border-bottom:1px solid var(--sand);font-family:var(--font-display); }
.mobile-register { background:var(--sage) !important;color:white !important;text-align:center;border-radius:var(--radius);margin-top:12px; }

/* Search Overlay */
.search-overlay { position:absolute;top:100%;left:0;right:0;background:white;box-shadow:var(--shadow-xl);opacity:0;visibility:hidden;transform:translateY(-10px);transition:var(--transition);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg); }
.search-overlay.active { opacity:1;visibility:visible;transform:translateY(0); }
.search-overlay-inner { max-width:var(--container-max);margin:0 auto;padding:20px 28px;display:flex;align-items:center;gap:12px; }
.search-overlay-inner input { flex:1;border:none;outline:none;font-size:1.15rem;padding:10px 0;background:none; }
.search-close { font-size:1.2rem;color:var(--text-muted);padding:8px; }
.search-results { max-width:var(--container-max);margin:0 auto;padding:0 28px 20px; }
.search-result-item { display:flex;align-items:center;gap:12px;padding:14px;border-radius:var(--radius-sm);cursor:pointer; }
.search-result-item:hover { background:var(--sage-50); }
.search-result-type { font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--sage);background:var(--sage-50);padding:3px 10px;border-radius:6px;min-width:70px;text-align:center; }

/* Hero */
.hero { position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;padding:calc(var(--header-height) + 20px) 0 100px; }
.hero-bg { position:absolute;inset:0;background:linear-gradient(165deg,#2d3e33 0%,#3a5441 25%,#5a7563 50%,#7c9885 75%,#a8c5b2 100%); }
.hero-gradient { position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 40%,rgba(201,169,110,0.15) 0%,transparent 60%),radial-gradient(ellipse 60% 80% at 80% 30%,rgba(168,197,178,0.2) 0%,transparent 50%),radial-gradient(ellipse 50% 50% at 50% 90%,rgba(30,30,30,0.4) 0%,transparent 70%); }
.hero-orbs { position:absolute;inset:0;overflow:hidden; }
.hero-orb { position:absolute;border-radius:50%;filter:blur(80px);opacity:0.35;animation:orbFloat 20s infinite ease-in-out; }
.hero-orb-1 { width:500px;height:500px;background:rgba(124,152,133,0.4);top:5%;left:-10%;animation-delay:0s; }
.hero-orb-2 { width:400px;height:400px;background:rgba(201,169,110,0.25);top:45%;right:-8%;animation-delay:-7s; }
.hero-orb-3 { width:450px;height:450px;background:rgba(168,197,178,0.3);bottom:-15%;left:25%;animation-delay:-14s; }
@keyframes orbFloat { 0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(40px,-50px) scale(1.05)}50%{transform:translate(-30px,30px) scale(0.95)}75%{transform:translate(50px,40px) scale(1.03)} }
.hero-noise { position:absolute;inset:0;opacity:0.03;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E"); }
.hero-particles { position:absolute;inset:0;overflow:hidden; }
.hero-particle { position:absolute;width:3px;height:3px;background:rgba(255,255,255,0.25);border-radius:50%;animation:float 18s infinite ease-in-out; }
@keyframes float { 0%,100%{transform:translateY(0) translateX(0);opacity:0}10%{opacity:0.8}50%{transform:translateY(-250px) translateX(60px)}90%{opacity:0.8} }

.hero-content { position:relative;z-index:2;text-align:center;max-width:800px;padding:0 28px; }
.hero-badge { display:inline-flex;align-items:center;gap:8px;padding:10px 24px;background:rgba(255,255,255,0.15);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.2);border-radius:60px;font-size:0.82rem;font-weight:500;color:rgba(255,255,255,0.95);margin-bottom:28px;letter-spacing:0.08em;text-transform:uppercase; }
.hero-badge-dot { width:6px;height:6px;background:var(--gold-light);border-radius:50%;animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1}50%{opacity:0.3} }
.hero-title { font-family:var(--font-display);font-size:clamp(3rem,7.5vw,5.5rem);font-weight:700;color:white;line-height:1.05;margin-bottom:24px;letter-spacing:-0.03em; }
.hero-title em { font-style:italic;background:linear-gradient(135deg,var(--gold-light),var(--terracotta-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }
.hero-subtitle { font-size:1.15rem;color:rgba(255,255,255,0.7);max-width:520px;margin:0 auto 40px;line-height:1.7;font-weight:300; }

/* Hero Search */
.hero-search { position:relative;max-width:580px;margin:0 auto 32px; }
.hero-search-inner { display:flex;align-items:center;background:rgba(255,255,255,0.95);backdrop-filter:blur(20px);border-radius:60px;padding:6px 6px 6px 24px;box-shadow:var(--shadow-xl),0 0 0 1px rgba(255,255,255,0.1);transition:var(--transition); }
.hero-search-inner:focus-within { box-shadow:var(--shadow-xl),0 0 0 2px var(--sage-light);transform:scale(1.02); }
.hero-search-icon { color:var(--text-muted);flex-shrink:0; }
.hero-search-inner input { flex:1;border:none;outline:none;padding:14px 12px;font-size:1rem;background:none; }
.hero-search-btn { padding:14px 32px;background:linear-gradient(135deg,var(--sage),var(--sage-dark));color:white;border-radius:60px;font-weight:600;font-size:0.92rem;box-shadow:0 2px 12px rgba(124,152,133,0.3); }
.hero-search-btn:hover { transform:scale(1.02); }
.hero-search-results { position:absolute;top:calc(100% + 10px);left:0;right:0;background:white;border-radius:var(--radius);box-shadow:var(--shadow-xl);display:none;max-height:320px;overflow-y:auto;padding:8px; }
.hero-search-results.active { display:block; }
.hero-tags { display:flex;flex-wrap:wrap;justify-content:center;gap:10px; }
.hero-tags a { padding:10px 20px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.1);border-radius:60px;color:rgba(255,255,255,0.75);font-size:0.85rem;font-weight:400;backdrop-filter:blur(10px);transition:var(--transition); }
.hero-tags a:hover { background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.2);transform:translateY(-2px); }
.hero-scroll { position:relative;z-index:2;margin-top:20px;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,0.4);font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase; }
.hero-scroll-line { width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,0.4),transparent);animation:scrollLine 2s infinite; }
@keyframes scrollLine { 0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom} }

/* Stats Bar */
.stats-bar { position:relative;z-index:3;padding:0 28px;margin-top:48px;width:100%;max-width:var(--container-max);margin-left:auto;margin-right:auto; }
.stats-bar-inner { max-width:900px;margin:0 auto;background:rgba(255,255,255,0.12);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius-xl);padding:32px 48px; }
.stats-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center; }
.stat-item { position:relative; }
.stat-item:not(:last-child)::after { content:'';position:absolute;right:0;top:10%;height:80%;width:1px;background:rgba(255,255,255,0.15); }
.stat-number { display:block;font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:white;letter-spacing:-0.02em; }
.stat-label { font-size:0.85rem;color:rgba(255,255,255,0.7);font-weight:400;margin-top:4px; }

/* Section Headers */
.section-header { display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;gap:20px; }
.section-header.centered { flex-direction:column;align-items:center;text-align:center; }
.section-badge { display:inline-flex;align-items:center;gap:8px;font-size:0.78rem;font-weight:600;text-transform:uppercase;letter-spacing:0.15em;color:var(--sage);margin-bottom:10px; }
.section-badge-line { width:32px;height:1px;background:var(--sage-light); }
.section-title { font-size:clamp(2rem,3.5vw,2.8rem);letter-spacing:-0.03em;font-weight:700; }
.section-subtitle { margin-top:10px;color:var(--text-muted);font-size:1.05rem;font-weight:300;max-width:500px; }
.section-link { font-weight:600;color:var(--sage);white-space:nowrap;display:inline-flex;align-items:center;gap:6px; }
.section-link:hover { color:var(--sage-dark);gap:10px; }

/* Event Cards */
.events-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px; }
.events-grid-4 { grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); }
.event-card { background:white;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition);display:flex;flex-direction:column;border:1px solid rgba(0,0,0,0.03); }
.event-card:hover { box-shadow:var(--shadow-card-hover);transform:translateY(-8px); }
.event-card-image { position:relative;aspect-ratio:16/10;overflow:hidden;background:linear-gradient(135deg,var(--sage-50),var(--sand)); }
.event-card-image img { width:100%;height:100%;object-fit:cover;transition:transform 0.6s var(--ease-out); }
.event-card:hover .event-card-image img { transform:scale(1.08); }
.event-card-image::after { content:'';position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,rgba(0,0,0,0.12),transparent);pointer-events:none; }
.badge-featured { position:absolute;top:14px;left:14px;background:linear-gradient(135deg,var(--gold),var(--terracotta));color:white;padding:5px 14px;border-radius:60px;font-size:0.72rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;z-index:1;box-shadow:0 2px 8px rgba(201,169,110,0.3); }
.event-date-badge { position:absolute;top:14px;right:14px;background:white;padding:8px 14px;border-radius:var(--radius-sm);text-align:center;line-height:1.1;box-shadow:var(--shadow);z-index:1; }
.event-date-badge strong { display:block;font-size:1.3rem;color:var(--sage-dark);font-family:var(--font-display); }
.event-date-badge span { font-size:0.65rem;text-transform:uppercase;color:var(--text-muted);font-weight:600;letter-spacing:0.05em; }
.event-card-body { padding:20px 24px 24px;flex:1;display:flex;flex-direction:column; }
.event-category { font-size:0.72rem;font-weight:700;color:var(--sage);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:8px; }
.event-card-title { font-family:var(--font-display);font-size:1.25rem;font-weight:600;margin-bottom:12px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }
.event-meta { display:flex;gap:16px;font-size:0.82rem;color:var(--text-muted);margin-top:auto;padding-top:12px;border-top:1px solid var(--sand-light); }
.event-price { display:inline-flex;align-items:center;margin-top:12px;font-weight:700;color:var(--sage-dark);font-size:1.05rem;font-family:var(--font-display); }
.event-price.free { color:var(--success); }

/* Studio Cards */
.studios-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px; }
.studio-card { background:white;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition);border:1px solid rgba(0,0,0,0.03); }
.studio-card:hover { transform:translateY(-8px);box-shadow:var(--shadow-card-hover); }
.studio-card-image { position:relative;aspect-ratio:16/10;overflow:hidden;background:linear-gradient(135deg,var(--sage-50),var(--sand)); }
.studio-card-image img { width:100%;height:100%;object-fit:cover;transition:transform 0.6s var(--ease-out); }
.studio-card:hover .studio-card-image img { transform:scale(1.08); }
.badge-premium { position:absolute;top:14px;left:14px;background:linear-gradient(135deg,var(--gold),#d4a74a);color:white;padding:5px 14px;border-radius:60px;font-size:0.72rem;font-weight:700;z-index:1;text-transform:uppercase;letter-spacing:0.04em; }
.badge-verified { position:absolute;top:14px;right:14px;background:var(--sage);color:white;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.8rem;z-index:1; }
.studio-card-body { padding:20px 24px 24px; }
.studio-card-body h3 { font-family:var(--font-display);font-size:1.2rem;font-weight:600;margin-bottom:4px; }
.studio-category { font-size:0.78rem;color:var(--sage);font-weight:500; }
.studio-meta { display:flex;justify-content:space-between;align-items:center;margin-top:12px;font-size:0.85rem;color:var(--text-muted); }
.studio-rating { color:var(--gold);font-weight:600; }

/* Category Cards */
.categories-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px; }
.category-card { text-align:center;padding:36px 20px;background:white;border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);transition:var(--transition);border:1px solid rgba(0,0,0,0.03);position:relative;overflow:hidden; }
.category-card::before { content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,var(--sage-50) 0%,transparent 70%);opacity:0;transition:opacity 0.4s; }
.category-card:hover { transform:translateY(-6px);box-shadow:var(--shadow-md),var(--shadow-glow); }
.category-card:hover::before { opacity:1; }
.category-icon { font-size:2.5rem;margin-bottom:14px;position:relative; }
.category-card h3 { font-family:var(--font-display);font-size:1.1rem;margin-bottom:6px;position:relative; }
.category-card p { font-size:0.82rem;color:var(--text-muted);position:relative; }

/* Tour Cards */
.tours-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px; }
.tour-card { background:white;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition);border:1px solid rgba(0,0,0,0.03); }
.tour-card:hover { transform:translateY(-8px);box-shadow:var(--shadow-card-hover); }
.tour-card-image { position:relative;aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,var(--sage-50),var(--sand)); }
.tour-card-image img { width:100%;height:100%;object-fit:cover;transition:transform 0.6s var(--ease-out); }
.tour-card:hover .tour-card-image img { transform:scale(1.08); }
.tour-duration { position:absolute;bottom:14px;left:14px;background:rgba(0,0,0,0.5);backdrop-filter:blur(10px);color:white;padding:6px 14px;border-radius:60px;font-size:0.78rem;font-weight:600; }
.tour-card-body { padding:22px 24px 24px; }
.tour-category { font-size:0.72rem;font-weight:700;color:var(--sage);text-transform:uppercase;letter-spacing:0.08em; }
.tour-card-body h3 { font-family:var(--font-display);font-size:1.25rem;margin:8px 0 10px; }
.tour-card-body p { font-size:0.88rem;color:var(--text-muted);margin-bottom:14px; }
.tour-meta { display:flex;gap:18px;font-size:0.82rem;color:var(--text-muted);margin-bottom:14px; }
.tour-price { display:flex;align-items:center;gap:10px; }
.old-price { text-decoration:line-through;color:var(--text-muted);font-size:0.9rem; }
.current-price { font-weight:700;color:var(--sage-dark);font-size:1.2rem;font-family:var(--font-display); }

/* City Cards */
.cities-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:18px; }
.city-card { position:relative;aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(135deg,var(--sage),var(--sage-dark));display:flex;align-items:flex-end;transition:var(--transition); }
.city-card:hover { transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-md); }
.city-card-overlay { position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,0.6) 100%); }
.city-card-content { position:relative;z-index:1;padding:18px;color:white; }
.city-card-content h3 { font-size:1.1rem;color:white;margin-bottom:4px;font-family:var(--font-display); }
.city-stats { display:flex;gap:8px;font-size:0.72rem;opacity:0.8; }
.cities-cta { text-align:center;margin-top:36px; }

/* CTA */
.cta-section { padding:100px 0;background:var(--off-white); }
.cta-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px; }
.cta-card { padding:56px 40px;border-radius:var(--radius-xl);text-align:center;color:white;position:relative;overflow:hidden;transition:var(--transition); }
.cta-card:hover { transform:translateY(-4px); }
.cta-card::before { content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,0.1),transparent 60%); }
.cta-studio { background:linear-gradient(135deg,var(--sage),var(--sage-900)); }
.cta-organizer { background:linear-gradient(135deg,var(--terracotta),var(--earth-dark)); }
.cta-card-icon { font-size:3rem;margin-bottom:20px;position:relative; }
.cta-card h3 { font-size:1.5rem;color:white;margin-bottom:14px;position:relative; }
.cta-card p { opacity:0.8;margin-bottom:28px;max-width:340px;margin-left:auto;margin-right:auto;position:relative;font-weight:300; }

/* Page Hero */
.page-hero { padding:140px 0 56px;background:linear-gradient(135deg,var(--sage-50),var(--sand-light));text-align:center;margin-top:var(--header-height);position:relative;overflow:hidden; }
.page-hero::before { content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(124,152,133,0.08),transparent 70%);top:-300px;right:-100px; }
.page-hero h1 { font-size:clamp(2.2rem,4vw,3rem);margin-bottom:14px;position:relative; }
.page-hero p { color:var(--text-muted);font-size:1.05rem;max-width:600px;margin:0 auto;position:relative;font-weight:300; }

/* Filters */
.filter-bar { background:white;padding:18px 24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:36px;border:1px solid rgba(0,0,0,0.03); }
.filter-form { display:flex;gap:12px;flex-wrap:wrap;align-items:center; }
.filter-form select,.filter-form input[type="date"] { padding:11px 18px;border:1px solid var(--sand-dark);border-radius:var(--radius-sm);background:white;color:var(--text-secondary);min-width:160px;outline:none;transition:var(--transition-fast); }
.filter-form select:focus,.filter-form input:focus { border-color:var(--sage);box-shadow:0 0 0 3px var(--sage-50); }
.filter-search { display:flex;flex:1;min-width:200px;gap:8px; }
.filter-search input { flex:1;padding:11px 18px;border:1px solid var(--sand-dark);border-radius:var(--radius-sm);outline:none; }
.filter-search button { padding:11px 28px;background:linear-gradient(135deg,var(--sage),var(--sage-dark));color:white;border-radius:var(--radius-sm);font-weight:600; }
.results-info { display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;color:var(--text-muted);font-size:0.88rem; }
.view-toggle { display:flex;gap:4px; }
.view-btn { width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid var(--sand-dark);font-size:1.1rem;color:var(--text-muted); }
.view-btn.active { background:var(--sage-50);border-color:var(--sage-light);color:var(--sage); }

/* Pagination */
.pagination { display:flex;justify-content:center;gap:8px;margin-top:56px; }
.page-link { padding:10px 18px;border:1px solid var(--sand-dark);border-radius:var(--radius-sm);font-size:0.88rem;color:var(--text-secondary);transition:var(--transition-fast); }
.page-link:hover { border-color:var(--sage);color:var(--sage); }
.page-link.active { background:var(--sage);color:white;border-color:var(--sage); }

/* Event Detail */
.event-detail-hero { height:420px;background-size:cover;background-position:center;position:relative;margin-top:var(--header-height); }
.event-detail-hero-overlay { position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.2),rgba(0,0,0,0.5)); }
.event-detail-hero .container { position:relative;z-index:1;padding-top:36px; }
.breadcrumb { font-size:0.82rem;color:rgba(255,255,255,0.7); }
.breadcrumb a { color:rgba(255,255,255,0.8); }
.breadcrumb a:hover { color:white; }
.event-detail-grid { display:grid;grid-template-columns:1fr 380px;gap:40px;margin-top:-70px;position:relative;z-index:2;padding-bottom:80px; }
.event-detail-main { background:white;border-radius:var(--radius-xl);padding:44px;box-shadow:var(--shadow-md);border:1px solid rgba(0,0,0,0.03); }
.event-detail-header { margin-bottom:36px; }
.event-detail-header h1 { font-size:2.2rem;margin:10px 0 24px;letter-spacing:-0.02em; }
.event-detail-meta { display:flex;flex-wrap:wrap;gap:24px; }
.meta-item { display:flex;align-items:center;gap:10px;font-size:0.95rem;color:var(--text-secondary); }
.event-detail-content { line-height:1.9;color:var(--text-secondary); }
.instructor-section,.location-section { margin-top:44px;padding-top:36px;border-top:1px solid var(--sand); }
.instructor-section h3,.location-section h3 { font-size:1.3rem;margin-bottom:18px; }
.instructor-card { display:flex;gap:18px;align-items:flex-start; }
.instructor-avatar { width:68px;height:68px;border-radius:50%;object-fit:cover; }

/* Booking Card */
.booking-card { background:white;border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-md);position:sticky;top:calc(var(--header-height)+24px);border:1px solid rgba(0,0,0,0.03); }
.booking-card-price { text-align:center;margin-bottom:24px; }
.price-main { display:block;font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:var(--sage-dark); }
.price-main.free { color:var(--success); }
.price-old { text-decoration:line-through;color:var(--text-muted);font-size:1rem; }
.price-note { font-size:0.82rem;color:var(--terracotta);font-weight:600; }
.booking-capacity { margin-bottom:18px; }
.capacity-bar { height:6px;background:var(--sand);border-radius:3px;overflow:hidden;margin-bottom:8px; }
.capacity-fill { height:100%;background:linear-gradient(90deg,var(--sage),var(--sage-light));border-radius:3px;transition:width 0.5s var(--ease); }
.booking-capacity span { font-size:0.82rem;color:var(--text-muted); }
.btn-book { margin-bottom:10px;font-size:1rem;padding:16px; }
.btn-fav { margin-bottom:18px; }
.booking-share { display:flex;align-items:center;gap:12px;font-size:0.82rem;color:var(--text-muted);flex-wrap:wrap; }
.booking-share a { color:var(--sage);font-weight:600; }

/* Studio Detail */
.studio-detail-hero { height:380px;background-size:cover;background-position:center;position:relative;margin-top:var(--header-height); }
.studio-detail-hero-overlay { position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.15),rgba(0,0,0,0.5)); }
.studio-detail-grid { display:grid;grid-template-columns:1fr 360px;gap:40px;margin-top:-70px;position:relative;z-index:2;padding-bottom:80px; }
.studio-detail-main { background:white;border-radius:var(--radius-xl);padding:44px;box-shadow:var(--shadow-md);border:1px solid rgba(0,0,0,0.03); }
.studio-header-top { display:flex;justify-content:space-between;align-items:center;margin-bottom:12px; }
.studio-category-badge { font-size:0.78rem;font-weight:700;color:var(--sage);text-transform:uppercase;letter-spacing:0.08em; }
.badge-verified-lg { font-size:0.82rem;color:var(--sage);font-weight:600; }
.studio-detail-header h1 { font-size:2.2rem;margin-bottom:10px;letter-spacing:-0.02em; }
.studio-location { color:var(--text-muted);font-size:1rem; }
.studio-rating-lg { color:var(--gold);font-size:1.1rem;font-weight:600; }
.tag-list { display:flex;flex-wrap:wrap;gap:10px; }
.tag { padding:8px 16px;background:var(--sage-50);color:var(--sage-dark);border-radius:60px;font-size:0.82rem;font-weight:500; }
.studio-info-card,.studio-hours-card { background:white;border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-md);margin-bottom:20px;border:1px solid rgba(0,0,0,0.03); }
.studio-info-card h4,.studio-hours-card h4 { font-size:1.1rem;margin-bottom:18px; }
.info-row { display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--sand);font-size:0.9rem;color:var(--text-secondary); }
.hours-row { display:flex;justify-content:space-between;padding:10px 0;font-size:0.88rem;border-bottom:1px solid var(--sand); }
.events-list { display:flex;flex-direction:column;gap:14px; }
.event-list-item { display:flex;align-items:center;gap:18px;padding:18px;background:var(--sage-50);border-radius:var(--radius);transition:var(--transition-fast); }
.event-list-item:hover { background:var(--sage-100);transform:translateX(4px); }
.event-list-date { text-align:center;min-width:52px; }
.event-list-date strong { display:block;font-size:1.4rem;color:var(--sage);font-family:var(--font-display); }
.event-list-date span { font-size:0.68rem;text-transform:uppercase;color:var(--text-muted);font-weight:600; }
.event-list-info { flex:1; }
.event-list-info h4 { font-size:0.95rem;margin-bottom:2px; }
.event-list-info span { font-size:0.82rem;color:var(--text-muted); }
.event-list-price { font-weight:700;color:var(--sage-dark);white-space:nowrap;font-family:var(--font-display); }
.reviews-section { margin-top:44px;padding-top:36px;border-top:1px solid var(--sand); }
.review-item { padding:24px 0;border-bottom:1px solid var(--sand); }
.review-header { display:flex;align-items:center;gap:14px;margin-bottom:12px; }
.review-avatar { width:44px;height:44px;background:linear-gradient(135deg,var(--sage-light),var(--sage));color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700; }
.review-stars { margin-left:8px; }
.review-date { margin-left:auto;font-size:0.82rem;color:var(--text-muted); }

/* Auth Pages */
.auth-section { padding:60px 24px;min-height:90vh;display:flex;align-items:center;justify-content:center;margin-top:var(--header-height);background:var(--off-white);position:relative; }
.auth-card { background:white;border-radius:var(--radius-xl);padding:52px;width:100%;max-width:460px;box-shadow:var(--shadow-lg);border:1px solid rgba(0,0,0,0.03); }
.auth-card-register { max-width:540px; }
.auth-header { text-align:center;margin-bottom:36px; }
.auth-header h1 { font-size:2rem;margin-bottom:10px; }
.auth-header p { color:var(--text-muted);font-weight:300; }
.form-group { margin-bottom:22px; }
.form-group label { display:block;margin-bottom:8px;font-weight:500;font-size:0.88rem;color:var(--text-secondary); }
.form-group input,.form-group select,.form-group textarea { width:100%;padding:14px 18px;border:1px solid var(--sand-dark);border-radius:var(--radius-sm);outline:none;transition:var(--transition-fast);background:white; }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--sage);box-shadow:0 0 0 4px var(--sage-50); }
.form-row { display:grid;grid-template-columns:1fr 1fr;gap:16px; }
.auth-footer { text-align:center;margin-top:28px;font-size:0.9rem;color:var(--text-muted); }
.auth-footer a { color:var(--sage);font-weight:600; }

/* Profile */
.profile-header { display:flex;align-items:center;gap:24px;margin-bottom:44px;padding-top:calc(var(--header-height) + 36px); }
.profile-avatar-lg { width:88px;height:88px;background:linear-gradient(135deg,var(--sage),var(--sage-dark));color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:700;box-shadow:0 4px 16px rgba(124,152,133,0.3); }
.profile-role { font-size:0.85rem;color:var(--sage);font-weight:500; }
.profile-grid { display:grid;grid-template-columns:240px 1fr;gap:36px; }
.profile-nav { display:flex;flex-direction:column;gap:4px; }
.profile-nav a { padding:13px 18px;border-radius:var(--radius-sm);font-size:0.9rem;color:var(--text-secondary); }
.profile-nav a:hover { background:var(--sage-50); }
.profile-nav a.active { background:var(--sage-50);color:var(--sage);font-weight:600; }
.profile-info-card { background:white;border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,0.03); }
.profile-info-card h3 { margin-bottom:28px; }
.info-grid { display:grid;gap:18px; }
.info-grid > div { display:flex;flex-direction:column;gap:4px; }
.info-grid label { font-size:0.82rem;color:var(--text-muted);font-weight:500; }

/* Contact */
.contact-grid { display:grid;grid-template-columns:1fr 380px;gap:56px; }
.contact-form-wrap h2,.contact-info h2 { font-size:1.5rem;margin-bottom:28px; }
.contact-info-item { display:flex;gap:18px;margin-bottom:28px; }
.contact-info-item span { font-size:1.5rem; }
.contact-info-item h4 { font-size:1rem;margin-bottom:4px; }
.contact-info-item p { color:var(--text-muted);font-size:0.92rem; }

/* Blog */
.blog-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px; }
.blog-card { background:white;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition);border:1px solid rgba(0,0,0,0.03); }
.blog-card:hover { transform:translateY(-8px);box-shadow:var(--shadow-card-hover); }
.blog-card img { width:100%;aspect-ratio:16/9;object-fit:cover;transition:transform 0.6s var(--ease-out); }
.blog-card:hover img { transform:scale(1.06); }
.blog-card-body { padding:24px; }
.blog-date { font-size:0.78rem;color:var(--text-muted);font-weight:500; }
.blog-card-body h3 { font-size:1.2rem;margin:10px 0;font-family:var(--font-display); }
.blog-card-body p { font-size:0.88rem;color:var(--text-muted); }
.blog-detail { max-width:800px;margin:0 auto;padding-top:calc(var(--header-height)+44px); }
.blog-detail h1 { font-size:2.4rem;margin-bottom:14px; }
.blog-meta { color:var(--text-muted);font-size:0.88rem;margin-bottom:28px;display:flex;gap:18px; }
.blog-hero-img { border-radius:var(--radius-lg);margin-bottom:36px; }

/* Empty/Error */
.empty-state { text-align:center;padding:70px 24px; }
.empty-icon { font-size:3.5rem;margin-bottom:18px; }
.empty-state h3 { font-size:1.3rem;margin-bottom:10px; }
.empty-state p { color:var(--text-muted);margin-bottom:24px; }
.error-page { padding:180px 0 100px;text-align:center;margin-top:var(--header-height); }
.error-icon { font-size:4rem;display:block;margin-bottom:20px; }
.error-content h1 { font-size:6rem;color:var(--sage);margin-bottom:8px;font-family:var(--font-display); }
.error-content h2 { font-size:1.6rem;margin-bottom:14px; }
.error-content p { color:var(--text-muted);margin-bottom:28px; }
.similar-section { margin-top:70px;padding-top:44px;border-top:1px solid var(--sand); }
.similar-section h2 { font-size:1.5rem;margin-bottom:28px; }

/* Districts/SEO */
.city-seo-content { max-width:800px;margin-bottom:56px; }
.city-seo-content h2 { font-size:1.8rem;margin-bottom:18px; }
.city-seo-content p { color:var(--text-secondary);line-height:1.9; }
.districts-section { margin-bottom:56px; }
.districts-section h3 { font-size:1.4rem;margin-bottom:18px; }
.districts-grid { display:flex;flex-wrap:wrap;gap:10px; }
.district-link { padding:10px 18px;background:white;border:1px solid var(--sand-dark);border-radius:60px;font-size:0.85rem;color:var(--text-secondary);transition:var(--transition-fast); }
.district-link:hover { border-color:var(--sage);color:var(--sage);background:var(--sage-50); }

/* Footer */
.site-footer { background:var(--deep);color:rgba(255,255,255,0.6); }
.footer-top { padding:70px 0; }
.footer-grid { display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:48px; }
.footer-logo { font-family:var(--font-display);font-size:1.4rem;color:white;display:flex;align-items:center;gap:10px;margin-bottom:18px; }
.footer-logo strong { color:var(--sage-light); }
.footer-brand p { font-size:0.88rem;line-height:1.7;margin-bottom:24px; }
.social-links { display:flex;gap:12px; }
.social-link { width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.5);transition:var(--transition); }
.social-link:hover { background:var(--sage);color:white;transform:translateY(-2px); }
.footer-col h4 { color:white;font-size:0.95rem;margin-bottom:18px;font-weight:600; }
.footer-col a { display:block;padding:7px 0;font-size:0.85rem;color:rgba(255,255,255,0.45); }
.footer-col a:hover { color:var(--sage-light); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.06);padding:24px 0;text-align:center;font-size:0.82rem; }

/* Toast */
.toast-container { position:fixed;bottom:28px;right:28px;z-index:10000;display:flex;flex-direction:column;gap:10px; }
.toast { padding:16px 28px;border-radius:var(--radius);color:white;font-size:0.88rem;font-weight:500;box-shadow:var(--shadow-lg);animation:toastIn 0.4s var(--ease-out);max-width:400px;backdrop-filter:blur(10px); }
.toast-success { background:rgba(107,158,122,0.95); }
.toast-error { background:rgba(194,112,112,0.95); }
.toast-info { background:rgba(123,158,194,0.95); }
@keyframes toastIn { from{transform:translateX(100%) scale(0.9);opacity:0}to{transform:translateX(0) scale(1);opacity:1} }

/* Responsive */
@media(max-width:1024px){.event-detail-grid,.studio-detail-grid{grid-template-columns:1fr}.booking-card{position:static}.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){:root{--header-height:68px}.main-nav{display:none}.mobile-menu-btn{display:flex}.btn-login,.btn-register{display:none}.hero{min-height:90vh}.hero-title{font-size:2.6rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-item:not(:last-child)::after{display:none}.stats-bar-inner{padding:28px}.section{padding:64px 0}.section-header{flex-direction:column;align-items:flex-start}.events-grid,.studios-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.categories-grid{grid-template-columns:repeat(2,1fr)}.cities-grid{grid-template-columns:repeat(3,1fr)}.filter-form{flex-direction:column}.filter-form select,.filter-search{width:100%;min-width:auto}.event-detail-main,.studio-detail-main{padding:28px}.contact-grid{grid-template-columns:1fr}.profile-grid{grid-template-columns:1fr}.profile-nav{flex-direction:row;overflow-x:auto}.cta-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}.auth-card{padding:36px 28px}.cursor-dot,.cursor-ring{display:none !important}}
@media(max-width:480px){.hero-title{font-size:2.2rem}.hero-search-inner{flex-direction:column;border-radius:var(--radius-lg);padding:14px}.hero-search-btn{width:100%;border-radius:var(--radius-sm)}.hero-tags{gap:6px}.hero-tags a{font-size:0.78rem;padding:8px 14px}.cities-grid{grid-template-columns:repeat(2,1fr)}.categories-grid{grid-template-columns:1fr}.stat-number{font-size:1.8rem}}

@keyframes fadeInUp { from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)} }
.animate-in { animation:fadeInUp 0.7s var(--ease-out) forwards; }
[data-parallax] { transition:transform 0.1s linear; }
.tilt-card { transition:transform 0.15s var(--ease-out);transform-style:preserve-3d; }
.magnetic { transition:transform 0.3s var(--ease-out); }
