/* ===== UPAYI.CO — Global Styles v3 ===== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,500;1,600&family=Source+Sans+3:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root {
    --blue: #2B7DE9;
    --blue-deep: #1A5FCC;
    --blue-dark: #1550B0;
    --blue-navy: #0C2D6B;
    --blue-light: #4A9BFF;
    --blue-pale: #E6F0FF;
    --blue-wash: #F0F6FF;
    --amber: #FBB830;
    --amber-deep: #F0A015;
    --gold: #FFD600;
    --orange: #F06B22;
    --white: #FFFFFF;
    --off-white: #F6F7FA;
    --warm-gray: #F0F1F5;
    --gray-100: #E8E9EE;
    --gray-200: #D1D3DA;
    --gray-300: #B0B3BD;
    --gray-400: #8A8D9A;
    --gray-500: #6B6E7A;
    --gray-600: #4A4D5A;
    --gray-700: #2E3040;
    --text-primary: #1A1C28;
    --text-secondary: #4A4D5A;
    --text-muted: #8A8D9A;
    --border: #D1D3DA;
    --border-light: #E8E9EE;
    --green-confirm: #0D7A3E;
    --green-bg: #E8F5EE;
    --shadow-xs: 0 1px 2px rgba(13,43,94,0.04);
    --shadow-sm: 0 2px 8px rgba(13,43,94,0.06);
    --shadow-md: 0 4px 20px rgba(13,43,94,0.08);
    --shadow-lg: 0 12px 40px rgba(13,43,94,0.10);
    --shadow-xl: 0 24px 64px rgba(13,43,94,0.14);
    --radius: 8px; --radius-md: 12px; --radius-lg: 16px; --radius-xl: 24px;
    --font-display: 'Cormorant Garamond', Georgia, serif;
    --font-body: 'Source Sans 3', 'Segoe UI', system-ui, sans-serif;
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:17px; }
body { font-family:var(--font-body); color:var(--text-primary); background:var(--off-white); line-height:1.65; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
img { max-width:100%; display:block; }
a { color:inherit; }
button { cursor:pointer; font-family:inherit; }

/* ₹ patterns */
.rupee-pattern-light { position:relative; }
.rupee-pattern-light::before { content:''; position:absolute; inset:0; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Ctext x='40' y='48' font-family='Georgia,serif' font-size='28' font-weight='700' fill='%232B7DE9' fill-opacity='0.03' text-anchor='middle'%3E₹%3C/text%3E%3C/svg%3E"); pointer-events:none; z-index:0; }
.rupee-pattern-dark { position:relative; }
.rupee-pattern-dark::before { content:''; position:absolute; inset:0; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='90' viewBox='0 0 90 90'%3E%3Ctext x='45' y='55' font-family='Georgia,serif' font-size='32' font-weight='700' fill='%23FFFFFF' fill-opacity='0.025' text-anchor='middle'%3E₹%3C/text%3E%3C/svg%3E"); pointer-events:none; z-index:0; }

/* Stripe */
.govt-stripe { background:linear-gradient(90deg,var(--blue) 0%,var(--amber) 60%,var(--orange) 100%); height:4px; position:fixed; top:0; left:0; right:0; z-index:10001; }

/* Navbar */
.navbar { position:fixed; top:4px; left:0; right:0; z-index:10000; background:rgba(255,255,255,0.92); backdrop-filter:blur(24px); border-bottom:1px solid transparent; transition:all 0.3s; }
.navbar.scrolled { background:rgba(255,255,255,0.97); border-bottom-color:var(--border-light); box-shadow:var(--shadow-sm); }
.navbar-inner { max-width:1240px; margin:0 auto; padding:0 28px; display:flex; align-items:center; justify-content:space-between; height:88px; }
.logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.logo-img { height:120px; width:auto; }
.logo-text { font-family:var(--font-display); font-weight:700; font-size:1.65rem; color:var(--blue-deep); letter-spacing:-0.5px; }
.logo-text .tld { color:var(--amber); font-style:italic; }
.nav-links { display:flex; align-items:center; gap:6px; list-style:none; }
.nav-links a { text-decoration:none; color:var(--text-secondary); font-size:0.92rem; font-weight:500; padding:9px 18px; border-radius:8px; transition:all 0.2s; }
.nav-links a:hover { color:var(--blue); background:var(--blue-pale); }
.nav-cta { background:var(--blue) !important; color:white !important; padding:11px 26px !important; border-radius:50px !important; font-weight:600 !important; }
.nav-cta:hover { background:var(--blue-light) !important; box-shadow:0 4px 20px rgba(27,95,188,0.3) !important; transform:translateY(-1px); }
.mobile-toggle { display:none; flex-direction:column; gap:5px; padding:10px; background:none; border:none; }
.mobile-toggle span { width:24px; height:2px; background:var(--blue-deep); border-radius:2px; }
.mobile-nav-overlay { display:none; position:fixed; inset:0; background:rgba(9,29,66,0.4); backdrop-filter:blur(4px); z-index:9998; }
.mobile-nav-overlay.open { display:block; }
.mobile-nav { display:none; position:fixed; top:0; right:-300px; width:290px; height:100%; background:var(--white); z-index:9999; padding:80px 28px 28px; transition:right 0.35s var(--ease-out); box-shadow:-10px 0 40px rgba(0,0,0,0.08); }
.mobile-nav.open { right:0; }
.mobile-nav a { display:block; padding:15px 0; font-size:1.05rem; font-weight:600; color:var(--blue-deep); text-decoration:none; border-bottom:1px solid var(--border-light); }
.mobile-nav .mobile-cta { display:block; text-align:center; margin-top:24px; padding:14px 24px; background:var(--blue); color:white; border-radius:50px; border:none; font-weight:600; }
.mobile-nav-close { position:absolute; top:20px; right:20px; background:none; border:none; font-size:1.6rem; color:var(--blue-deep); padding:8px; }

/* Sections */
section, .page-section { padding:110px 28px; }
.container { max-width:1240px; margin:0 auto; position:relative; z-index:1; }
.section-label { display:inline-flex; align-items:center; gap:10px; font-size:0.78rem; font-weight:700; color:var(--blue); text-transform:uppercase; letter-spacing:3px; margin-bottom:16px; }
.section-label::before { content:''; width:32px; height:2px; background:var(--amber); }
.section-title { font-family:var(--font-display); font-size:clamp(2.4rem,4.5vw,3.6rem); font-weight:600; color:var(--blue-dark); line-height:1.12; margin-bottom:18px; letter-spacing:-0.5px; }
.section-title em { font-style:italic; color:var(--orange); }
.section-subtitle { font-size:1.15rem; color:var(--text-secondary); max-width:600px; line-height:1.75; }
.section-center { text-align:center; }
.section-center .section-subtitle { margin:0 auto; }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:10px; padding:16px 36px; border-radius:50px; font-size:1rem; font-weight:600; text-decoration:none; border:none; font-family:inherit; transition:all 0.3s var(--ease-out); }
.btn-primary { background:var(--blue); color:white; }
.btn-primary:hover { background:var(--blue-light); transform:translateY(-2px); box-shadow:0 8px 28px rgba(27,95,188,0.3); }
.btn-secondary { background:var(--white); color:var(--blue-deep); border:2px solid var(--border); }
.btn-secondary:hover { border-color:var(--blue); background:var(--blue); color:white; transform:translateY(-2px); }
.btn-amber { background:var(--amber); color:var(--blue-navy); }
.btn-amber:hover { background:var(--gold); transform:translateY(-2px); box-shadow:0 8px 28px rgba(245,166,35,0.35); }
.btn-ghost { background:transparent; color:rgba(255,255,255,0.8); border:2px solid rgba(255,255,255,0.2); }
.btn-ghost:hover { background:rgba(255,255,255,0.08); border-color:rgba(255,255,255,0.4); color:white; }

/* Icon boxes */
.icon-box { width:56px; height:56px; border-radius:14px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.icon-box svg { width:28px; height:28px; }
.icon-box-blue { background:var(--blue-pale); color:var(--blue); }
.icon-box-amber { background:rgba(245,166,35,0.1); color:var(--amber-deep); }
.icon-box-green { background:var(--green-bg); color:var(--green-confirm); }
.icon-box-dark { background:rgba(9,29,66,0.06); color:var(--blue-dark); }
.icon-box-lg { width:64px; height:64px; border-radius:16px; margin-bottom:22px; }
.icon-box-lg svg { width:32px; height:32px; }

/* Widget */
.widget-demo { background:var(--white); border-radius:var(--radius-xl); box-shadow:var(--shadow-xl); border:1px solid var(--border-light); overflow:hidden; }
.widget-header { display:flex; align-items:center; justify-content:space-between; padding:20px 28px; border-bottom:1px solid var(--border-light); background:var(--blue-wash); }
.widget-brand { font-family:var(--font-display); font-weight:700; font-size:1.1rem; color:var(--blue-deep); }
.widget-live { display:flex; align-items:center; gap:6px; font-size:0.72rem; font-weight:700; color:var(--green-confirm); background:var(--green-bg); padding:5px 14px; border-radius:20px; text-transform:uppercase; letter-spacing:0.5px; }
.widget-live-dot { width:7px; height:7px; background:var(--green-confirm); border-radius:50%; animation:pulse-dot 2s infinite; }
@keyframes pulse-dot { 0%,100%{opacity:1;} 50%{opacity:0.3;} }
.widget-body { padding:28px; }
.widget-amount-label { font-size:0.78rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:2.5px; font-weight:700; margin-bottom:6px; }
.widget-amount { font-family:var(--font-display); font-size:3.2rem; font-weight:700; color:var(--blue-dark); margin-bottom:28px; line-height:1; }
.widget-amount .rupee { font-size:2rem; color:var(--gray-400); vertical-align:top; margin-right:2px; }

/* Pay tabs */
.pay-tabs { display:flex; margin-bottom:24px; border-radius:var(--radius-md); overflow:hidden; border:2px solid var(--border); background:var(--off-white); }
.pay-tab { flex:1; text-align:center; padding:16px 8px; cursor:pointer; transition:all 0.3s; background:transparent; border:none; position:relative; font-family:inherit; }
.pay-tab::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--blue); transform:scaleX(0); transition:transform 0.3s var(--ease-out); }
.pay-tab.active { background:var(--white); }
.pay-tab.active::after { transform:scaleX(1); }
.pay-tab-icon { display:block; height:26px; margin:0 auto 6px; color:var(--gray-400); transition:color 0.3s; }
.pay-tab.active .pay-tab-icon { color:var(--blue); }
.pay-tab-label { font-size:0.72rem; font-weight:700; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; transition:color 0.3s; }
.pay-tab.active .pay-tab-label { color:var(--blue-deep); }
.pay-panel { display:none; min-height:210px; }
.pay-panel.active { display:block; animation:panelIn 0.4s var(--ease-out); }
@keyframes panelIn { from{opacity:0;transform:translateY(8px);} to{opacity:1;transform:translateY(0);} }

/* QR */
.qr-display { display:flex; flex-direction:column; align-items:center; padding:8px 0; }
.qr-frame { width:190px; height:190px; background:var(--white); border:2px solid var(--border); border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; margin-bottom:16px; overflow:hidden; }
.qr-placeholder { width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; color:var(--gray-400); }
.qr-placeholder img { width:100%; height:100%; object-fit:contain; padding:8px; }
.qr-scan-hint { font-size:0.88rem; color:var(--text-muted); font-weight:500; display:flex; align-items:center; gap:8px; }

/* Phone */
.phone-display { text-align:center; padding:24px 0; }
.phone-number-big { font-family:var(--font-display); font-size:2.8rem; font-weight:700; color:var(--blue-dark); letter-spacing:3px; margin-bottom:10px; line-height:1.2; }
.phone-number-big .country-code { font-size:1.5rem; color:var(--gray-400); margin-right:4px; }
.phone-hint { font-size:0.88rem; color:var(--text-muted); margin-bottom:18px; }
.upi-apps-row { display:flex; justify-content:center; gap:10px; flex-wrap:wrap; }
.upi-app-badge { padding:7px 18px; border-radius:20px; font-size:0.78rem; font-weight:600; background:var(--blue-wash); border:1px solid var(--border-light); color:var(--blue-deep); }

/* UPI ID */
.upi-display { text-align:center; padding:24px 0; }
.upi-id-box { display:inline-flex; align-items:center; gap:12px; background:var(--blue-wash); border:2px solid var(--border); border-radius:var(--radius-md); padding:16px 28px; margin-bottom:12px; }
.upi-id-text { font-size:1.25rem; font-weight:700; color:var(--blue-dark); letter-spacing:0.5px; }
.upi-copy-btn { width:36px; height:36px; border-radius:8px; border:1px solid var(--border); background:var(--white); display:flex; align-items:center; justify-content:center; transition:all 0.2s; color:var(--gray-400); }
.upi-copy-btn:hover { background:var(--blue); color:white; border-color:var(--blue); }
.upi-hint { font-size:0.88rem; color:var(--text-muted); }
.widget-pay-btn { width:100%; padding:17px; background:linear-gradient(135deg,var(--blue) 0%,var(--blue-deep) 100%); color:white; border:none; border-radius:var(--radius); font-size:1.05rem; font-weight:700; transition:all 0.3s; letter-spacing:0.5px; margin-top:4px; }
.widget-pay-btn:hover { box-shadow:0 6px 24px rgba(27,95,188,0.35); transform:translateY(-1px); }
.widget-secure { text-align:center; margin-top:14px; font-size:0.78rem; color:var(--text-muted); display:flex; align-items:center; justify-content:center; gap:8px; }

/* Float badges */
.float-badge { position:absolute; background:var(--white); border-radius:var(--radius-lg); padding:12px 20px; box-shadow:var(--shadow-lg); border:1px solid var(--border-light); font-size:0.88rem; font-weight:600; display:flex; align-items:center; gap:10px; animation:float 5s ease-in-out infinite; z-index:2; color:var(--blue-deep); }
@keyframes float { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-10px);} }

/* Trust bar */
.trust-bar { background:var(--blue-navy); padding:32px 28px; position:relative; overflow:hidden; }
.trust-bar-inner { max-width:1240px; margin:0 auto; display:flex; align-items:center; justify-content:center; gap:48px; flex-wrap:wrap; position:relative; z-index:1; }
.trust-item { display:flex; align-items:center; gap:12px; color:rgba(255,255,255,0.6); font-size:0.92rem; font-weight:500; }
.trust-icon { width:40px; height:40px; background:rgba(255,255,255,0.06); border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--amber); }
.trust-icon svg { width:20px; height:20px; }
.trust-item strong { color:white; }

/* Steps */
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; }
.step-card { padding:44px; position:relative; border-right:1px solid var(--border-light); }
.step-card:last-child { border-right:none; }
.step-num { font-family:var(--font-display); font-size:5.5rem; font-weight:700; color:var(--blue-pale); line-height:1; margin-bottom:18px; position:relative; }
.step-num::after { content:attr(data-n); position:absolute; top:50%; left:22px; transform:translateY(-50%); font-size:1.05rem; color:var(--blue); font-weight:700; font-family:var(--font-body); }
.step-card h3 { font-size:1.2rem; font-weight:700; color:var(--blue-dark); margin-bottom:10px; }
.step-card p { font-size:1rem; color:var(--text-secondary); line-height:1.7; }

/* Features */
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.feature-card { background:var(--white); border-radius:var(--radius-lg); padding:36px; border:1px solid var(--border-light); transition:all 0.35s var(--ease-out); position:relative; overflow:hidden; }
.feature-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--blue),var(--orange)); transform:scaleX(0); transform-origin:left; transition:transform 0.4s var(--ease-out); }
.feature-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.feature-card:hover::before { transform:scaleX(1); }
.feature-card h3 { font-size:1.12rem; font-weight:700; color:var(--blue-dark); margin-bottom:10px; }
.feature-card p { font-size:0.98rem; color:var(--text-secondary); line-height:1.7; }

/* Use case cards */
.usecase-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:22px; }
.usecase-card { background:var(--white); border-radius:var(--radius-lg); padding:36px; border:1px solid var(--border-light); transition:all 0.35s var(--ease-out); position:relative; overflow:hidden; text-decoration:none; display:block; }
.usecase-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--amber); transform:scaleX(0); transform-origin:left; transition:transform 0.4s var(--ease-out); }
.usecase-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.usecase-card:hover::before { transform:scaleX(1); }
.usecase-card h3 { font-family:var(--font-display); font-size:1.4rem; font-weight:600; color:var(--blue-dark); margin-bottom:10px; }
.usecase-card p { font-size:0.98rem; color:var(--text-secondary); line-height:1.7; margin-bottom:18px; }
.usecase-link { font-size:0.88rem; font-weight:600; color:var(--blue); text-decoration:none; display:inline-flex; align-items:center; gap:6px; transition:gap 0.2s; }
.usecase-card:hover .usecase-link { gap:10px; }

/* Roadmap dark */
.roadmap-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.roadmap-card { background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:var(--radius-lg); padding:36px; text-align:center; transition:all 0.35s var(--ease-out); }
.roadmap-card:hover { background:rgba(255,255,255,0.08); border-color:rgba(245,166,35,0.3); transform:translateY(-4px); }
.roadmap-card h3 { color:white; font-size:1.1rem; font-weight:700; margin-bottom:10px; }
.roadmap-card p { color:rgba(255,255,255,0.5); font-size:0.92rem; line-height:1.65; }

/* Waitlist */
.waitlist-form { display:flex; gap:12px; max-width:520px; margin:0 auto 16px; }
.waitlist-form input { flex:1; padding:16px 22px; border:2px solid var(--border); border-radius:50px; font-size:1rem; font-family:inherit; background:var(--white); transition:border-color 0.3s; outline:none; }
.waitlist-form input:focus { border-color:var(--blue); }
.form-msg { display:none; padding:14px 22px; border-radius:var(--radius); font-weight:600; font-size:0.95rem; max-width:520px; margin:0 auto; }
.form-msg.success { display:block; background:var(--green-bg); color:var(--green-confirm); }
.form-msg.error { display:block; background:rgba(192,57,43,0.08); color:#c0392b; }
.waitlist-note { font-size:0.84rem; color:var(--text-muted); margin-top:10px; }

/* FAQ */
.faq-container { max-width:800px; margin:0 auto; }
.faq-item { background:var(--white); border:1px solid var(--border-light); border-radius:var(--radius-lg); margin-bottom:12px; overflow:hidden; transition:border-color 0.3s; }
.faq-item:hover { border-color:var(--border); }
.faq-q { width:100%; padding:22px 28px; background:none; border:none; font-size:1.05rem; font-weight:600; color:var(--blue-dark); text-align:left; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:16px; font-family:inherit; }
.faq-chevron { color:var(--gray-400); transition:transform 0.3s; flex-shrink:0; }
.faq-item.open .faq-chevron { transform:rotate(180deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height 0.4s ease; }
.faq-a-inner { padding:0 28px 22px; font-size:1rem; color:var(--text-secondary); line-height:1.75; }

/* Footer */
.footer { background:var(--blue-navy); padding:64px 28px 0; color:rgba(255,255,255,0.5); }
.footer-inner { max-width:1240px; margin:0 auto; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,0.06); }
.footer-brand p { font-size:0.95rem; line-height:1.7; max-width:320px; margin-top:16px; }
.footer-col h4 { color:white; font-size:0.78rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; margin-bottom:20px; }
.footer-col a { display:block; color:rgba(255,255,255,0.4); text-decoration:none; font-size:0.95rem; margin-bottom:12px; transition:color 0.2s; }
.footer-col a:hover { color:var(--amber); }
.footer-bottom { padding:24px 0; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; font-size:0.82rem; }
.footer-bottom a { color:rgba(255,255,255,0.4); text-decoration:none; transition:color 0.2s; }
.footer-bottom a:hover { color:var(--amber); }
.footer-disclaimer { font-size:0.78rem; padding:20px 0; border-top:1px solid rgba(255,255,255,0.04); color:rgba(255,255,255,0.28); line-height:1.6; }
.footer-stripe { height:4px; background:linear-gradient(90deg,var(--blue) 0%,var(--amber) 60%,var(--orange) 100%); }

/* Page hero */
.page-hero { padding:140px 28px 80px; background:var(--off-white); position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; top:-150px; right:-150px; width:500px; height:500px; background:radial-gradient(circle,rgba(27,95,188,0.06) 0%,transparent 70%); border-radius:50%; }
.page-hero .container { position:relative; z-index:1; }
.page-hero .section-title { font-size:clamp(2.4rem,5vw,3.6rem); max-width:700px; }
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:0.88rem; color:var(--text-muted); margin-bottom:24px; }
.breadcrumb a { text-decoration:none; color:var(--text-muted); transition:color 0.2s; }
.breadcrumb a:hover { color:var(--blue); }
.breadcrumb .sep { opacity:0.4; }

/* Use-case page */
.uc-hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.uc-benefits { list-style:none; margin-top:28px; }
.uc-benefits li { padding:11px 0; display:flex; align-items:flex-start; gap:14px; font-size:1.02rem; color:var(--text-secondary); line-height:1.6; }
.uc-benefits .check-icon { width:24px; height:24px; border-radius:50%; background:var(--green-bg); display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:2px; color:var(--green-confirm); }
.uc-benefits .check-icon svg { width:12px; height:12px; }
.uc-scenario { background:var(--white); border-radius:var(--radius-lg); padding:40px; border:1px solid var(--border-light); }

/* Section BGs */
.bg-white { background:var(--white); }
.bg-off-white { background:var(--off-white); }
.bg-blue-wash { background:var(--blue-wash); }
.bg-navy { background:var(--blue-navy); color:white; }
.bg-blue-dark { background:var(--blue-dark); color:white; }
.bg-navy .section-title, .bg-blue-dark .section-title { color:white; }
.bg-navy .section-title em, .bg-blue-dark .section-title em { color:var(--gold); }
.bg-navy .section-subtitle, .bg-blue-dark .section-subtitle { color:rgba(255,255,255,0.55); }
.bg-navy .section-label, .bg-blue-dark .section-label { color:var(--amber); }
.bg-navy .section-label::before, .bg-blue-dark .section-label::before { background:var(--amber); }

/* Reveal */
.reveal { opacity:0; transform:translateY(28px); transition:all 0.7s var(--ease-out); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* Legal */
.legal-body { max-width:800px; margin:0 auto; }
.legal-body h2 { font-family:var(--font-display); font-size:1.55rem; font-weight:600; color:var(--blue-dark); margin:44px 0 14px; }
.legal-body h2:first-of-type { margin-top:0; }
.legal-body p { color:var(--text-secondary); line-height:1.85; margin-bottom:16px; font-size:1rem; }
.legal-body ul, .legal-body ol { color:var(--text-secondary); line-height:1.85; margin:0 0 16px 22px; font-size:1rem; }
.legal-body li { margin-bottom:8px; }
.legal-body strong { color:var(--text-primary); }
.legal-updated { font-size:0.88rem; color:var(--text-muted); margin-bottom:36px; }
.legal-body a { color:var(--blue); }

/* Contact */
.contact-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:22px; max-width:840px; margin:0 auto; }
.contact-card { background:var(--white); border:1px solid var(--border-light); border-radius:var(--radius-lg); padding:40px; text-align:center; transition:all 0.3s var(--ease-out); }
.contact-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.contact-card h3 { font-family:var(--font-display); font-size:1.3rem; font-weight:600; color:var(--blue-dark); margin-bottom:10px; }
.contact-card p { color:var(--text-secondary); font-size:0.98rem; line-height:1.65; margin-bottom:18px; }
.contact-card a.contact-link { color:var(--blue); font-weight:600; font-size:0.95rem; text-decoration:none; display:inline-flex; align-items:center; gap:6px; transition:gap 0.2s; }
.contact-card:hover a.contact-link { gap:10px; }
@media (max-width:600px) { .contact-grid { grid-template-columns:1fr; } }

/* Responsive */
@media (max-width:1024px) {
    .uc-hero-grid { grid-template-columns:1fr; gap:40px; }
    .steps-grid { grid-template-columns:1fr; }
    .step-card { border-right:none; border-bottom:1px solid var(--border-light); }
    .step-card:last-child { border-bottom:none; }
    .features-grid { grid-template-columns:repeat(2,1fr); }
    .roadmap-grid { grid-template-columns:1fr; max-width:420px; margin:0 auto; }
    .footer-top { grid-template-columns:1fr 1fr; gap:36px; }
}
@media (max-width:768px) {
    html { font-size:16px; }
    .nav-links { display:none; }
    .mobile-toggle { display:flex; }
    .mobile-nav { display:block; }
    section, .page-section { padding:80px 20px; }
    .page-hero { padding:110px 20px 60px; }
    .features-grid { grid-template-columns:1fr; }
    .usecase-grid { grid-template-columns:1fr; }
    .waitlist-form { flex-direction:column; }
    .waitlist-form button { width:100%; justify-content:center; }
    .footer-top { grid-template-columns:1fr; }
    .footer-bottom { flex-direction:column; text-align:center; }
    .float-badge { display:none; }
    .widget-body { padding:22px; }
    .phone-number-big { font-size:2.1rem; }
    .trust-bar-inner { gap:20px; }
    .trust-item { font-size:0.82rem; }
}
@media (max-width:480px) {
    .section-title { font-size:2.1rem; }
    .widget-amount { font-size:2.6rem; }
    .pay-tab-label { font-size:0.62rem; }
    .navbar-inner { padding:0 16px; }
}

/* Logo responsive sizing */
@media (max-width:768px) {
    .logo-img { height:72px !important; }
    .navbar-inner { height:72px !important; }
}
@media (max-width:480px) {
    .logo-img { height:56px !important; }
    .navbar-inner { height:64px !important; }
}

/* Dark section input contrast */
input[style*="border-color:rgba(255"]::placeholder,
.bg-navy input::placeholder {
    color: rgba(255,255,255,0.4) !important;
}

/* Ensure check-icon is properly styled globally */
.check-icon { width:24px; height:24px; border-radius:50%; background:var(--green-bg); display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:3px; color:var(--green-confirm); }
.check-icon svg { width:13px; height:13px; }

/* Dark section text contrast improvements */
.bg-navy p, .bg-blue-dark p { color: rgba(255,255,255,0.65); }
.bg-navy h2, .bg-blue-dark h2 { color: white; }
.bg-navy strong, .bg-blue-dark strong { color: white; }
.bg-navy a, .bg-blue-dark a { color: var(--amber); }
