/* ============================================================
   Itwar Bazar — Premium Creative Design System v3
   Unique Mesh-Gradient / Glass / Bento Layout
   Full-Bleed Mobile | Deep Teal + Violet
   ============================================================ */

:root {
    --primary: #0d9488;
    --primary-dark: #0f766e;
    --primary-light: #5eead4;
    --primary-ultra-light: #ccfbf1;
    --primary-glow: rgba(13,148,136,0.1);
    --accent: #7c3aed;
    --accent-light: #a78bfa;
    --accent-glow: rgba(124,58,237,0.08);
    --rose: #f43f5e;
    --amber: #f59e0b;
    --sky: #0ea5e9;

    --gradient-primary: linear-gradient(135deg, #0d9488 0%, #7c3aed 100%);
    --gradient-hero: linear-gradient(135deg, #0f172a 0%, #134e4a 35%, #1e1b4b 70%, #0f172a 100%);
    --gradient-mesh: radial-gradient(ellipse at 20% 50%, rgba(13,148,136,0.15) 0%, transparent 50%),
                     radial-gradient(ellipse at 80% 20%, rgba(124,58,237,0.12) 0%, transparent 50%),
                     radial-gradient(ellipse at 50% 80%, rgba(244,63,94,0.06) 0%, transparent 50%);
    --gradient-glass: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0.02) 100%);
    --gradient-dark: linear-gradient(135deg, #0f172a 0%, #1e1b4b 100%);
    --gradient-card-shine: linear-gradient(135deg, rgba(255,255,255,0.9) 0%, rgba(255,255,255,0.4) 100%);

    --surface: #fafbfc;
    --surface-card: #ffffff;
    --surface-dark: #0a0e1a;
    --surface-muted: #f1f5f9;
    --surface-warm: #fef7f0;
    --text-primary: #0f172a;
    --text-secondary: #475569;
    --text-muted: #94a3b8;
    --text-white: #ffffff;
    --border: rgba(148,163,184,0.12);
    --border-hover: rgba(13,148,136,0.25);
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.04);
    --shadow-md: 0 4px 20px rgba(0,0,0,0.06);
    --shadow-lg: 0 12px 40px rgba(0,0,0,0.08);
    --shadow-xl: 0 20px 60px rgba(0,0,0,0.1);
    --shadow-color: 0 8px 32px rgba(13,148,136,0.12);
    --radius-sm: 10px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --radius-xl: 24px;
    --radius-2xl: 32px;
    --radius-full: 100px;
    --font-heading: 'Outfit', sans-serif;
    --font-body: 'Inter', sans-serif;
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --transition-fast: 0.2s var(--ease-out);
    --transition-base: 0.35s var(--ease-out);
    --transition-slow: 0.6s var(--ease-out);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
body { background:var(--surface); color:var(--text-primary); font-family:var(--font-body); font-size:15px; line-height:1.7; overflow-x:hidden; }
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
h1,h2,h3,h4,h5,h6 { font-family:var(--font-heading); line-height:1.15; color:var(--text-primary); }

/* --- Layout --- */
.container { max-width:1180px; margin:0 auto; padding:0 24px; }
.section { padding:80px 0; position:relative; }

/* --- Scroll Animations --- */
.reveal { opacity:0; transform:translateY(32px); transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:0.1s; }
.reveal-delay-2 { transition-delay:0.2s; }
.reveal-delay-3 { transition-delay:0.3s; }
.reveal-delay-4 { transition-delay:0.4s; }
.reveal-left { opacity:0; transform:translateX(-40px); 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(40px); 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.92); transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out); }
.reveal-scale.visible { opacity:1; transform:scale(1); }

@keyframes float { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-10px); } }
@keyframes pulse-ring { 0% { box-shadow:0 0 0 0 rgba(13,148,136,0.4); } 70% { box-shadow:0 0 0 12px rgba(13,148,136,0); } 100% { box-shadow:0 0 0 0 rgba(13,148,136,0); } }
@keyframes fade-up { from { opacity:0; transform:translateY(30px); } to { opacity:1; transform:translateY(0); } }
@keyframes spin-slow { from { transform:rotate(0deg); } to { transform:rotate(360deg); } }
@keyframes gradient-move { 0%,100% { background-position:0% 50%; } 50% { background-position:100% 50%; } }
@keyframes blob { 0%,100% { border-radius:60% 40% 30% 70%/60% 30% 70% 40%; } 50% { border-radius:30% 60% 70% 40%/50% 60% 30% 60%; } }

/* ============ HEADER ============ */
.main-header {
    position:fixed; top:0; left:0; right:0; z-index:1000;
    background:rgba(250,251,252,0.75);
    backdrop-filter:blur(20px) saturate(180%); -webkit-backdrop-filter:blur(20px) saturate(180%);
    border-bottom:1px solid rgba(148,163,184,0.08);
    transition:var(--transition-base);
}
.main-header.scrolled { background:rgba(255,255,255,0.92); box-shadow:0 1px 20px rgba(0,0,0,0.05); }
.nav-container { display:flex; justify-content:space-between; align-items:center; height:68px; }
.logo a { display:flex; align-items:center; }
.logo-text { font-family:var(--font-heading); font-size:26px; font-weight:800; letter-spacing:-0.03em; }
.logo-text { color:var(--primary); }
.logo-text span { background:var(--gradient-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.nav-links { display:flex; gap:6px; }
.nav-links a { padding:8px 18px; font-weight:500; font-size:14px; color:var(--text-secondary); border-radius:var(--radius-full); transition:var(--transition-fast); position:relative; }
.nav-links a:hover { color:var(--primary); background:var(--primary-glow); }
.nav-links a.active { color:var(--primary); background:var(--primary-glow); font-weight:600; }
.header-actions .btn-sm { padding:10px 24px; font-size:13px; border-radius:var(--radius-full); }
.mobile-menu-toggle { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; z-index:1001; }
.mobile-menu-toggle span { width:22px; height:2px; background:var(--text-primary); border-radius:2px; transition:var(--transition-fast); display:block; }
.mobile-menu-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.mobile-menu-toggle.active span:nth-child(2) { opacity:0; }
.mobile-menu-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ============ BUTTONS ============ */
.btn {
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    padding:14px 32px; border-radius:var(--radius-full); font-weight:600; font-size:14px;
    font-family:var(--font-body); cursor:pointer; border:none; transition:var(--transition-base);
    position:relative; overflow:hidden; letter-spacing:0.01em;
}
.btn-primary { background:var(--gradient-primary); color:#fff; box-shadow:0 4px 20px rgba(13,148,136,0.25); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(13,148,136,0.35); }
.btn-primary:active { transform:translateY(0); }
.btn-outline { background:transparent; border:2px solid rgba(255,255,255,0.25); color:#fff; backdrop-filter:blur(4px); }
.btn-outline:hover { background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.5); transform:translateY(-2px); }
.btn-light { background:var(--surface-card); color:var(--text-primary); box-shadow:var(--shadow-md); border:1px solid var(--border); }
.btn-light:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg); border-color:var(--border-hover); }
.btn-white { background:rgba(255,255,255,0.95); color:var(--primary); box-shadow:var(--shadow-md); }
.btn-white:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.btn-ghost { background:transparent; border:2px solid var(--primary); color:var(--primary); }
.btn-ghost:hover { background:var(--primary); color:#fff; transform:translateY(-2px); }

/* ============ HERO — DARK MESH ============ */
.hero {
    min-height:100vh; display:flex; align-items:center; justify-content:center;
    background:var(--gradient-hero); position:relative; overflow:hidden;
    padding:120px 0 100px; text-align:center;
}
.hero::before {
    content:''; position:absolute; inset:0;
    background:var(--gradient-mesh);
    animation:gradient-move 12s ease-in-out infinite;
    background-size:200% 200%;
}
.hero-blob-1 {
    position:absolute; top:10%; left:5%; width:320px; height:320px;
    background:rgba(13,148,136,0.08); filter:blur(80px);
    border-radius:60% 40% 30% 70%/60% 30% 70% 40%;
    animation:blob 10s ease-in-out infinite;
}
.hero-blob-2 {
    position:absolute; bottom:10%; right:5%; width:280px; height:280px;
    background:rgba(124,58,237,0.08); filter:blur(80px);
    border-radius:30% 60% 70% 40%/50% 60% 30% 60%;
    animation:blob 12s ease-in-out infinite reverse;
}
.hero .container { position:relative; z-index:2; }
.hero-badge {
    display:inline-flex; align-items:center; gap:10px; padding:8px 20px;
    background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1);
    border-radius:var(--radius-full); font-size:13px; font-weight:600;
    color:var(--primary-light); margin-bottom:28px;
    backdrop-filter:blur(8px);
    animation:fade-up 0.6s var(--ease-out) both;
}
.badge-dot { width:8px; height:8px; background:var(--primary-light); border-radius:50%; animation:pulse-ring 2s infinite; }
.hero h1 {
    font-size:clamp(32px,5.5vw,62px); font-weight:800; letter-spacing:-0.04em;
    color:#fff; margin-bottom:20px; line-height:1.1;
    animation:fade-up 0.6s var(--ease-out) 0.1s both;
}
.text-gradient { background:linear-gradient(135deg, var(--primary-light) 0%, var(--accent-light) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero .hero-subtitle {
    font-size:17px; line-height:1.8; color:rgba(255,255,255,0.6); max-width:620px;
    margin:0 auto 36px; animation:fade-up 0.6s var(--ease-out) 0.2s both;
}
.hero-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; animation:fade-up 0.6s var(--ease-out) 0.3s both; }

/* --- Countdown --- */
.countdown-wrapper { margin-top:48px; animation:fade-up 0.6s var(--ease-out) 0.4s both; }
.countdown-label-top { font-size:11px; text-transform:uppercase; letter-spacing:0.15em; color:rgba(255,255,255,0.35); font-weight:600; margin-bottom:14px; }
.countdown-container { display:flex; justify-content:center; gap:14px; }
.countdown-item {
    background:rgba(255,255,255,0.05); backdrop-filter:blur(12px);
    border:1px solid rgba(255,255,255,0.08); padding:20px 16px;
    border-radius:var(--radius-lg); min-width:84px; transition:var(--transition-base);
}
.countdown-item:hover { background:rgba(255,255,255,0.08); border-color:rgba(255,255,255,0.15); transform:translateY(-3px); }
.countdown-number {
    display:block; font-family:var(--font-heading); font-size:32px; font-weight:800;
    background:linear-gradient(135deg, var(--primary-light), var(--accent-light));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.countdown-unit { font-size:10px; text-transform:uppercase; color:rgba(255,255,255,0.35); letter-spacing:0.12em; font-weight:600; margin-top:4px; display:block; }

/* --- Wave Divider --- */
.wave-divider { position:absolute; bottom:-1px; left:0; right:0; line-height:0; }
.wave-divider svg { display:block; width:100%; height:auto; }
.wave-divider-top { position:absolute; top:-1px; left:0; right:0; line-height:0; }
.wave-divider-top svg { display:block; width:100%; height:auto; }

/* ============ SECTION HEADERS ============ */
.section-header { max-width:580px; margin:0 auto 52px; text-align:center; }
.section-tag {
    display:inline-flex; align-items:center; gap:8px; padding:6px 16px;
    background:var(--primary-glow); border:1px solid rgba(13,148,136,0.1);
    border-radius:var(--radius-full); font-size:11px; font-weight:700;
    text-transform:uppercase; letter-spacing:0.12em; color:var(--primary-dark); margin-bottom:14px;
}
.section-tag-dot { width:6px; height:6px; border-radius:50%; background:var(--primary); }
.section-header h2 { font-size:clamp(26px,3.8vw,38px); font-weight:800; letter-spacing:-0.03em; margin-bottom:12px; }
.section-header p { color:var(--text-secondary); font-size:15px; line-height:1.7; }

/* ============ BENTO FEATURES ============ */
.bento-grid {
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    grid-template-rows:auto auto;
    gap:18px;
}
.bento-card {
    background:var(--surface-card); border:1px solid var(--border);
    border-radius:var(--radius-xl); padding:32px 28px;
    transition:var(--transition-base); position:relative; overflow:hidden;
}
.bento-card::before {
    content:''; position:absolute; inset:-1px; border-radius:inherit;
    background:var(--gradient-primary); z-index:-1; opacity:0;
    transition:opacity 0.4s var(--ease-out);
}
.bento-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.bento-card:hover::before { opacity:1; }
.bento-card:hover { border-color:transparent; }
.bento-card-inner { position:relative; z-index:1; background:var(--surface-card); border-radius:calc(var(--radius-xl) - 2px); }
.bento-card .card-icon {
    width:52px; height:52px; display:flex; align-items:center; justify-content:center;
    border-radius:var(--radius-md); margin-bottom:18px;
    transition:var(--transition-base);
}
.bento-card .card-icon svg { width:24px; height:24px; }
.bento-card:hover .card-icon { transform:scale(1.1) rotate(-3deg); }
.bento-card h3 { font-size:17px; font-weight:700; margin-bottom:8px; }
.bento-card p { font-size:13.5px; color:var(--text-secondary); line-height:1.7; }

/* Icon color variations */
.icon-teal { background:var(--primary-glow); color:var(--primary); }
.icon-violet { background:var(--accent-glow); color:var(--accent); }
.icon-rose { background:rgba(244,63,94,0.08); color:var(--rose); }
.icon-amber { background:rgba(245,158,11,0.08); color:var(--amber); }
.icon-sky { background:rgba(14,165,233,0.08); color:var(--sky); }

/* Span the first card across 2 columns for bento effect */
.bento-card.bento-wide { grid-column:span 2; }

/* ============ STATS — INLINE GLASS ============ */
.stats-ribbon {
    background:var(--gradient-dark); padding:0; position:relative; overflow:hidden;
}
.stats-ribbon::before {
    content:''; position:absolute; inset:0;
    background:var(--gradient-mesh); opacity:0.5;
}
.stats-inner {
    display:flex; justify-content:space-around; align-items:center;
    padding:48px 24px; position:relative; z-index:1; flex-wrap:wrap; gap:20px;
}
.stat-block { text-align:center; flex:1; min-width:140px; }
.stat-block h3 { font-size:clamp(30px,4vw,48px); font-weight:800; color:var(--primary-light); margin-bottom:2px; }
.stat-block p { font-size:13px; color:rgba(255,255,255,0.5); font-weight:500; }
.stat-divider { width:1px; height:48px; background:rgba(255,255,255,0.08); flex-shrink:0; }

/* ============ CATEGORIES — SCROLLABLE PILLS ============ */
.categories-scroll-section { background:var(--surface); }
.categories-track {
    display:flex; gap:14px; overflow-x:auto; padding-bottom:8px;
    scrollbar-width:none; -ms-overflow-style:none;
    scroll-snap-type:x mandatory;
}
.categories-track::-webkit-scrollbar { display:none; }
.cat-pill {
    flex:0 0 auto; display:flex; align-items:center; gap:14px;
    background:var(--surface-card); border:1px solid var(--border);
    border-radius:var(--radius-full); padding:14px 28px 14px 16px;
    cursor:pointer; transition:var(--transition-base);
    scroll-snap-align:start; white-space:nowrap;
}
.cat-pill:hover { transform:translateY(-3px); box-shadow:var(--shadow-color); border-color:var(--border-hover); }
.cat-pill-icon {
    width:44px; height:44px; display:flex; align-items:center; justify-content:center;
    border-radius:50%; flex-shrink:0; transition:var(--transition-base);
}
.cat-pill:hover .cat-pill-icon { transform:scale(1.08); }
.cat-pill-icon svg { width:20px; height:20px; }
.cat-pill-text h4 { font-size:14px; font-weight:700; margin-bottom:1px; }
.cat-pill-text p { font-size:11px; color:var(--text-muted); }

/* cat pill icon color cycle */
.cat-pill:nth-child(1) .cat-pill-icon { background:var(--primary-glow); color:var(--primary); }
.cat-pill:nth-child(2) .cat-pill-icon { background:var(--accent-glow); color:var(--accent); }
.cat-pill:nth-child(3) .cat-pill-icon { background:rgba(244,63,94,0.08); color:var(--rose); }
.cat-pill:nth-child(4) .cat-pill-icon { background:rgba(245,158,11,0.08); color:var(--amber); }
.cat-pill:nth-child(5) .cat-pill-icon { background:rgba(14,165,233,0.08); color:var(--sky); }
.cat-pill:nth-child(6) .cat-pill-icon { background:rgba(16,185,129,0.08); color:#10b981; }

/* ============ TIMELINE STEPS ============ */
.timeline-section { background:var(--surface-warm); }
.timeline { display:flex; flex-direction:column; gap:0; max-width:700px; margin:0 auto; position:relative; }
.timeline::before {
    content:''; position:absolute; left:28px; top:0; bottom:0; width:2px;
    background:linear-gradient(180deg, var(--primary), var(--accent), var(--primary));
    opacity:0.15; border-radius:2px;
}
.timeline-item {
    display:flex; gap:24px; padding:28px 0; position:relative;
}
.timeline-dot {
    width:56px; height:56px; min-width:56px; display:flex; align-items:center; justify-content:center;
    background:var(--surface-card); border:2px solid var(--primary); border-radius:50%;
    font-family:var(--font-heading); font-size:20px; font-weight:800; color:var(--primary);
    position:relative; z-index:2; transition:var(--transition-base);
    box-shadow:0 0 0 6px var(--surface-warm);
}
.timeline-item:hover .timeline-dot {
    background:var(--gradient-primary); color:#fff; border-color:transparent;
    transform:scale(1.08); box-shadow:0 0 0 6px var(--surface-warm), 0 4px 20px rgba(13,148,136,0.25);
}
.timeline-content h3 { font-size:18px; font-weight:700; margin-bottom:6px; }
.timeline-content p { font-size:14px; color:var(--text-secondary); line-height:1.75; }

/* ============ SEO CONTENT ============ */
.content-section { background:var(--surface-card); }
.content-wrapper { max-width:760px; margin:0 auto; }
.content-wrapper h2 {
    font-size:clamp(20px,2.5vw,26px); color:var(--text-primary); margin:40px 0 14px;
    padding-left:16px; position:relative;
}
.content-wrapper h2::before {
    content:''; position:absolute; left:0; top:4px; bottom:4px; width:4px;
    background:var(--gradient-primary); border-radius:4px;
}
.content-wrapper p { color:var(--text-secondary); margin-bottom:16px; font-size:15px; line-height:1.85; }
.content-wrapper ul { margin:12px 0 20px; }
.content-wrapper ul li { padding:7px 0 7px 28px; position:relative; color:var(--text-secondary); line-height:1.75; font-size:14px; }
.content-wrapper ul li::before {
    content:''; position:absolute; left:6px; top:16px; width:8px; height:8px;
    border-radius:50%; border:2px solid var(--primary); background:var(--primary-glow);
}
.content-wrapper strong { color:var(--text-primary); }

/* ============ TESTIMONIALS — MODERN CARDS ============ */
.testimonials-section { background:var(--surface-muted); }
.testimonial-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.testi-card {
    background:var(--surface-card); border:1px solid var(--border);
    border-radius:var(--radius-xl); padding:32px 28px;
    transition:var(--transition-base); position:relative;
}
.testi-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.testi-stars { display:flex; gap:3px; margin-bottom:14px; }
.testi-stars svg { width:15px; height:15px; color:#f59e0b; fill:#f59e0b; }
.testi-quote {
    font-size:14.5px; color:var(--text-secondary); margin-bottom:20px;
    font-style:italic; line-height:1.8; position:relative; padding-left:16px;
}
.testi-quote::before {
    content:''; position:absolute; left:0; top:4px; bottom:4px;
    width:3px; border-radius:3px; background:var(--gradient-primary);
}
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-avatar {
    width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center;
    font-weight:700; font-size:14px; color:#fff;
}
.testi-card:nth-child(1) .testi-avatar { background:var(--gradient-primary); }
.testi-card:nth-child(2) .testi-avatar { background:linear-gradient(135deg, var(--accent), var(--rose)); }
.testi-card:nth-child(3) .testi-avatar { background:linear-gradient(135deg, var(--sky), var(--primary)); }
.testi-author strong { display:block; font-size:14px; }
.testi-author span { font-size:12px; color:var(--text-muted); }

/* ============ CTA — GRADIENT BAND ============ */
.cta-section {
    background:var(--gradient-dark); text-align:center; position:relative; overflow:hidden;
    padding:80px 0;
}
.cta-section::before {
    content:''; position:absolute; inset:0;
    background:var(--gradient-mesh); opacity:0.4;
}
.cta-section .container { position:relative; z-index:1; }
.cta-section h2 { font-size:clamp(26px,3.8vw,40px); color:#fff; margin-bottom:14px; font-weight:800; letter-spacing:-0.03em; }
.cta-section p { color:rgba(255,255,255,0.55); font-size:16px; max-width:540px; margin:0 auto 32px; line-height:1.75; }

/* ============ PAGE HERO (Inner Pages) ============ */
.page-hero {
    padding:130px 0 56px; text-align:center; position:relative; overflow:hidden;
    background:var(--gradient-dark);
}
.page-hero::before { content:''; position:absolute; inset:0; background:var(--gradient-mesh); opacity:0.3; }
.page-hero .container { position:relative; z-index:1; }
.page-hero h1 {
    font-size:clamp(28px,4.5vw,44px); font-weight:800; letter-spacing:-0.03em;
    color:#fff; margin-bottom:12px; animation:fade-up 0.6s var(--ease-out) both;
}
.page-hero .page-subtitle {
    font-size:15px; color:rgba(255,255,255,0.55); max-width:520px; margin:0 auto;
    animation:fade-up 0.6s var(--ease-out) 0.1s both; line-height:1.7;
}
.breadcrumb { margin-bottom:18px; animation:fade-up 0.6s var(--ease-out) both; }
.breadcrumb a { color:var(--primary-light); font-size:13px; font-weight:500; }
.breadcrumb span { color:rgba(255,255,255,0.35); font-size:13px; margin:0 8px; }

/* ============ CONTACT ============ */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:start; }
.contact-info-card {
    background:var(--gradient-dark); border-radius:var(--radius-xl); padding:36px;
    color:white; position:relative; overflow:hidden;
}
.contact-info-card::before {
    content:''; position:absolute; inset:0; background:var(--gradient-mesh); opacity:0.3;
}
.contact-info-card > * { position:relative; z-index:1; }
.contact-info-card h3 { color:white; font-size:22px; margin-bottom:6px; }
.contact-info-card > p { color:rgba(255,255,255,0.5); margin-bottom:28px; font-size:14px; }
.contact-detail { display:flex; align-items:flex-start; gap:14px; margin-bottom:22px; }
.contact-detail-icon {
    width:44px; height:44px; min-width:44px; display:flex; align-items:center; justify-content:center;
    background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.08);
    border-radius:var(--radius-md); color:var(--primary-light); transition:var(--transition-fast);
}
.contact-detail:hover .contact-detail-icon { background:rgba(255,255,255,0.1); transform:scale(1.05); }
.contact-detail-icon svg { width:20px; height:20px; }
.contact-detail h4 { color:white; font-size:14px; margin-bottom:2px; font-weight:600; }
.contact-detail p { color:rgba(255,255,255,0.5); font-size:13px; }
.form-card {
    background:var(--surface-card); border:1px solid var(--border);
    border-radius:var(--radius-xl); padding:36px;
}
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-weight:600; font-size:13px; margin-bottom:7px; color:var(--text-primary); }
.form-control {
    width:100%; padding:13px 16px; border:1.5px solid var(--border);
    border-radius:var(--radius-md); font-family:var(--font-body); font-size:14px;
    color:var(--text-primary); background:var(--surface); outline:none; transition:var(--transition-fast);
}
.form-control:focus { border-color:var(--primary); box-shadow:0 0 0 4px var(--primary-glow); background:#fff; }
textarea.form-control { resize:vertical; min-height:110px; }
.form-status { padding:12px 16px; border-radius:var(--radius-md); font-weight:500; font-size:13px; margin-top:14px; display:none; }
.form-status.success { background:#f0fdf4; color:#166534; border:1px solid #bbf7d0; display:block; }
.form-status.error { background:#fef2f2; color:#991b1b; border:1px solid #fecaca; display:block; }

/* ============ LEGAL PAGES ============ */
.legal-content { max-width:760px; margin:0 auto; padding:36px 24px 80px; }
.legal-content .last-updated {
    display:inline-flex; padding:6px 14px; background:var(--surface-muted);
    border-radius:var(--radius-full); font-size:12px; color:var(--text-muted); margin-bottom:36px;
}
.legal-content section { padding:0; margin-bottom:32px; }
.legal-content h2 { font-size:20px; margin-bottom:12px; padding-left:16px; position:relative; }
.legal-content h2::before { content:''; position:absolute; left:0; top:4px; bottom:4px; width:4px; background:var(--gradient-primary); border-radius:4px; }
.legal-content p { color:var(--text-secondary); line-height:1.85; margin-bottom:12px; font-size:14px; }
.legal-content ul { margin:12px 0 18px; }
.legal-content ul li { padding:6px 0 6px 24px; position:relative; color:var(--text-secondary); font-size:14px; line-height:1.7; }
.legal-content ul li::before { content:''; position:absolute; left:6px; top:14px; width:6px; height:6px; border-radius:50%; background:var(--primary); }

/* ============ ABOUT ============ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center; }
.about-text .section-tag { margin-bottom:12px; }
.about-text h2 { font-size:clamp(24px,3vw,32px); margin-bottom:14px; }
.about-text p { color:var(--text-secondary); margin-bottom:16px; line-height:1.85; font-size:14px; }
.about-visual {
    background:var(--gradient-dark); border-radius:var(--radius-2xl); padding:40px;
    color:white; position:relative; overflow:hidden;
}
.about-visual::before { content:''; position:absolute; inset:0; background:var(--gradient-mesh); opacity:0.3; }
.about-stat { position:relative; z-index:1; margin-bottom:26px; }
.about-stat:last-child { margin-bottom:0; }
.about-stat h3 { font-size:36px; font-weight:800; color:var(--primary-light); margin-bottom:2px; }
.about-stat p { font-size:13px; color:rgba(255,255,255,0.5); }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.value-card {
    background:var(--surface-card); border:1px solid var(--border);
    border-radius:var(--radius-xl); padding:30px 26px; transition:var(--transition-base);
}
.value-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.value-icon {
    width:50px; height:50px; display:flex; align-items:center; justify-content:center;
    border-radius:var(--radius-md); margin-bottom:16px;
}
.value-icon svg { width:22px; height:22px; }
.value-card h4 { font-size:16px; margin-bottom:8px; }
.value-card p { font-size:13px; color:var(--text-secondary); line-height:1.7; }
.value-card:nth-child(1) .value-icon { background:var(--primary-glow); color:var(--primary); }
.value-card:nth-child(2) .value-icon { background:var(--accent-glow); color:var(--accent); }
.value-card:nth-child(3) .value-icon { background:rgba(244,63,94,0.08); color:var(--rose); }
.value-card:nth-child(4) .value-icon { background:rgba(245,158,11,0.08); color:var(--amber); }
.value-card:nth-child(5) .value-icon { background:rgba(14,165,233,0.08); color:var(--sky); }
.value-card:nth-child(6) .value-icon { background:rgba(16,185,129,0.08); color:#10b981; }

/* ============ FOOTER ============ */
.main-footer { background:var(--surface-dark); padding:72px 0 0; color:rgba(255,255,255,0.8); }
.footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:44px; margin-bottom:52px; }
.footer-logo { display:flex; align-items:center; margin-bottom:14px; }
.footer-logo .logo-text { color:var(--primary-light); font-size:24px; }
.footer-logo .logo-text span { background:linear-gradient(135deg, var(--primary-light), var(--accent-light)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.footer-brand p { font-size:13px; color:rgba(255,255,255,0.35); line-height:1.8; max-width:300px; }
.footer-social { display:flex; gap:10px; margin-top:22px; }
.social-link {
    width:38px; height:38px; display:flex; align-items:center; justify-content:center;
    background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06);
    border-radius:50%; color:rgba(255,255,255,0.4); transition:var(--transition-fast);
}
.social-link:hover { background:var(--primary); border-color:var(--primary); color:white; transform:translateY(-2px); }
.social-link svg { width:16px; height:16px; }
.footer-links h4, .footer-contact h4 { font-family:var(--font-heading); font-size:14px; font-weight:700; color:white; margin-bottom:22px; }
.footer-links ul { display:flex; flex-direction:column; gap:12px; }
.footer-links a { font-size:13px; color:rgba(255,255,255,0.35); transition:var(--transition-fast); }
.footer-links a:hover { color:var(--primary-light); padding-left:4px; }
.footer-contact-item { display:flex; align-items:center; gap:12px; margin-bottom:16px; font-size:13px; color:rgba(255,255,255,0.35); }
.footer-contact-item .icon { color:var(--primary-light); }
.footer-contact-item svg { width:16px; height:16px; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.05); padding:22px 0; text-align:center; font-size:12px; color:rgba(255,255,255,0.25); }
.footer-bottom a { color:var(--primary-light); transition:var(--transition-fast); }
.footer-bottom a:hover { color:white; }


/* ============================================================
   RESPONSIVE — FULL BLEED MOBILE
   ============================================================ */

@media (max-width:1024px) {
    .bento-grid { grid-template-columns:repeat(2,1fr); }
    .bento-card.bento-wide { grid-column:span 1; }
    .testimonial-grid, .values-grid { grid-template-columns:repeat(2,1fr); }
    .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
    .about-grid, .contact-grid { grid-template-columns:1fr; gap:28px; }
    .stat-divider:nth-child(4) { display:none; }
}

@media (max-width:768px) {
    .container { padding:0 0; }
    .section { padding:56px 0; }

    /* Mobile nav */
    .nav-container { padding:0 14px; }
    .nav-links {
        position:fixed; top:0; right:-100%; width:280px; height:100vh;
        background:white; flex-direction:column; padding:80px 24px 24px;
        gap:2px; box-shadow:var(--shadow-xl); transition:right 0.35s var(--ease-out); z-index:999;
    }
    .nav-links.active { right:0; }
    .nav-links a { padding:14px 18px; font-size:15px; border-radius:var(--radius-md); }
    .mobile-menu-toggle { display:flex; }
    .header-actions { display:none; }

    /* Hero */
    .hero { padding:100px 16px 72px; min-height:auto; }
    .hero h1 { font-size:28px; }
    .hero .hero-subtitle { font-size:15px; margin-bottom:28px; padding:0 4px; }
    .countdown-container { gap:10px; }
    .countdown-item { min-width:66px; padding:16px 12px; }
    .countdown-number { font-size:26px; }

    /* Bento full bleed */
    .bento-grid { grid-template-columns:1fr; gap:14px; padding:0 14px; }
    .bento-card { border-radius:var(--radius-lg); padding:26px 22px; }

    /* Stats */
    .stats-inner { padding:36px 14px; gap:16px; }
    .stat-divider { display:none; }
    .stats-inner { display:grid; grid-template-columns:1fr 1fr; }
    .stat-block { padding:12px 0; }

    /* Categories */
    .categories-track { padding:0 14px 8px; gap:10px; }
    .cat-pill { padding:12px 22px 12px 14px; }

    /* Timeline */
    .timeline { padding:0 14px; }
    .timeline::before { left:27px; }
    .timeline-dot { width:50px; height:50px; min-width:50px; font-size:18px; }
    .timeline-content h3 { font-size:16px; }

    /* Testimonials */
    .testimonial-grid { grid-template-columns:1fr; gap:14px; padding:0 14px; }
    .testi-card { border-radius:var(--radius-lg); }

    /* Content */
    .content-wrapper { padding:0 14px; }
    .content-section { padding:56px 0; }

    /* CTA */
    .cta-section { padding:60px 16px; }

    /* Section headers */
    .section-header { margin-bottom:36px; padding:0 14px; }
    .section-header h2 { font-size:24px; }

    /* Page hero */
    .page-hero { padding:100px 16px 40px; }
    .page-hero h1 { font-size:26px; }

    /* About */
    .about-grid { padding:0 14px; }
    .about-visual { border-radius:var(--radius-xl); }

    /* Values */
    .values-grid { grid-template-columns:1fr; gap:14px; padding:0 14px; }

    /* Contact */
    .contact-grid { padding:0 14px; gap:18px; }
    .form-card, .contact-info-card { padding:28px 22px; border-radius:var(--radius-lg); }

    /* Legal */
    .legal-content { padding:28px 14px 64px; }

    /* Footer full bleed feel */
    .footer-grid { grid-template-columns:1fr; gap:28px; padding:0 16px; }
    .footer-bottom { padding:18px 14px; }
    .main-footer { padding:52px 0 0; }

    /* Mobile-specific helpers */
    .hero-actions { flex-direction:column; align-items:stretch; padding:0 12px; }
    .hero-actions .btn { width:100%; justify-content:center; }
}

@media (max-width:480px) {
    .hero { padding:90px 12px 60px; }
    .hero h1 { font-size:25px; letter-spacing:-0.03em; }
    .hero .hero-subtitle { font-size:14px; }
    .countdown-item { min-width:60px; padding:14px 10px; }
    .countdown-number { font-size:24px; }
    .bento-grid { padding:0 10px; }
    .bento-card { padding:22px 18px; }
    .categories-track { padding:0 10px 8px; }
    .section-header { padding:0 12px; }
    .timeline { padding:0 10px; }
    .testimonial-grid { padding:0 10px; }
    .content-wrapper { padding:0 12px; }
    .contact-grid { padding:0 10px; }
    .values-grid { padding:0 10px; }
    .about-grid { padding:0 10px; }
    .legal-content { padding:24px 12px 60px; }
    .footer-grid { padding:0 12px; }
}
