/*
Theme Name: Massachusetts Fun Company
Theme URI: https://mafuncompany.com
Author: Massachusetts Fun Company
Description: A vibrant multi-brand showcase theme for Massachusetts Fun Company
Version: 3.0.0
License: GNU General Public License v2 or later
Text Domain: ma-fun-company
*/


    :root {
      --color-primary:    #FF3B1F;
      --color-secondary:  #FFD600;
      --color-accent:     #00C2FF;
      --color-dark:       #0D0D1A;
      --color-mid:        #1E1E35;
      --color-white:      #FFFFFF;
      --grad-hero:        linear-gradient(135deg, #0D0D1A 0%, #1E1E35 60%, #2A1040 100%);
      --grad-primary:     linear-gradient(135deg, #FF3B1F, #FF8C00);
      --grad-secondary:   linear-gradient(135deg, #FFD600, #FF9500);
      --grad-accent:      linear-gradient(135deg, #00C2FF, #0057FF);
      --font-display:     'Bebas Neue', 'Impact', sans-serif;
      --font-heading:     'Montserrat', 'Helvetica Neue', sans-serif;
      --font-body:        'Inter', 'Segoe UI', sans-serif;
      --radius-sm: 8px; --radius-md: 16px; --radius-lg: 24px; --radius-xl: 40px;
    }
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body { font-family: var(--font-body); background: var(--color-dark); color: var(--color-white); line-height: 1.6; overflow-x: hidden; }
    img { max-width: 100%; height: auto; display: block; }
    a { color: inherit; text-decoration: none; }
    ul { list-style: none; }
    h1,h2,h3,h4 { font-family: var(--font-heading); font-weight: 800; line-height: 1.1; letter-spacing: -0.02em; }
    .eyebrow { font-family: var(--font-heading); font-size: 0.72rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-secondary); }
    .container { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 2rem; }
    .section-pad { padding: 7rem 0; }
    .text-center { text-align: center; }

    .btn { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.85rem 2rem; border-radius: var(--radius-xl); font-family: var(--font-heading); font-weight: 700; font-size: 0.95rem; letter-spacing: 0.04em; cursor: pointer; border: none; transition: transform 0.2s ease, box-shadow 0.2s ease; }
    .btn:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,0.3); }
    .btn-primary { background: var(--grad-primary); color: var(--color-white); box-shadow: 0 4px 20px rgba(255,59,31,0.4); }
    .btn-outline { background: transparent; color: var(--color-white); border: 2px solid rgba(255,255,255,0.3); }
    .btn-outline:hover { border-color: var(--color-secondary); color: var(--color-secondary); }
    .btn-white { background: white; color: var(--color-primary); }
    .btn-white-outline { background: transparent; color: white; border: 2px solid rgba(255,255,255,0.5); }

    /* NAV */
    .site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; padding: 1rem 0; transition: background 0.3s ease, padding 0.3s ease; }
    .site-header.scrolled { background: rgba(13,13,26,0.96); backdrop-filter: blur(12px); padding: 0.6rem 0; border-bottom: 1px solid rgba(255,255,255,0.07); }
    .nav-inner { display: flex; align-items: center; justify-content: space-between; }
    .site-logo { display: flex; flex-direction: column; line-height: 1; }
    .logo-main { font-family: var(--font-display); font-size: 1.6rem; letter-spacing: 0.06em; color: var(--color-white); text-transform: uppercase; }
    .logo-sub { font-family: var(--font-heading); font-size: 0.6rem; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-secondary); margin-top: 2px; }
    .nav-menu { display: flex; align-items: center; gap: 2.5rem; }
    .nav-menu a { font-family: var(--font-heading); font-size: 0.88rem; font-weight: 600; letter-spacing: 0.04em; color: rgba(255,255,255,0.8); transition: color 0.2s; }
    .nav-menu a:hover { color: var(--color-secondary); }
    .hamburger {
      display: none;
      flex-direction: column;
      gap: 5px;
      cursor: pointer;
      padding: 8px;
      background: none;
      border: none;
      z-index: 1001;
      position: relative;
    }
    .hamburger span { width: 26px; height: 2px; background: var(--color-white); border-radius: 2px; }

    /* MOBILE MENU */
    .mobile-menu { display: none; position: fixed; inset: 0; background: rgba(13,13,26,0.98); z-index: 999; flex-direction: column; align-items: center; justify-content: center; gap: 2rem; backdrop-filter: blur(20px); }
    .mobile-menu.open { display: flex; }
    .mobile-menu a { font-family: var(--font-display); font-size: 2.5rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-white); transition: color 0.2s; }
    .mobile-menu a:hover { color: var(--color-secondary); }
    .mobile-close {
      display: none;
      position: fixed;
      top: 1.2rem;
      right: 1.4rem;
      background: none;
      border: none;
      color: rgba(255,255,255,0.8);
      font-size: 2.8rem;
      cursor: pointer;
      line-height: 1;
      z-index: 1002;
      padding: 0;
    }
    .mobile-close:hover { color: var(--color-secondary); }
    .mobile-close.visible { display: block; }

    /* HERO */
    .hero { min-height: 100vh; background: var(--grad-hero); position: relative; display: flex; align-items: center; overflow: hidden; }
    .hero-bg-shapes { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
    .hero-blob { position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.25; }
    .hero-blob-1 { width: 600px; height: 600px; background: var(--color-primary); top: -200px; right: -100px; animation: floatBlob 8s ease-in-out infinite; }
    .hero-blob-2 { width: 400px; height: 400px; background: var(--color-accent); bottom: -100px; left: -80px; animation: floatBlob 10s ease-in-out infinite reverse; }
    .hero-blob-3 { width: 300px; height: 300px; background: var(--color-secondary); top: 50%; left: 50%; transform: translate(-50%,-50%); animation: floatBlob 12s ease-in-out infinite; }
    @keyframes floatBlob { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(30px,-20px) scale(1.05)} 66%{transform:translate(-20px,15px) scale(0.97)} }
    .hero::before { content:''; position:absolute; inset:0; background-image:radial-gradient(circle,rgba(255,255,255,0.07) 1px,transparent 1px); background-size:40px 40px; pointer-events:none; }
    .hero-content { position: relative; z-index: 2; padding: 120px 0 80px; width: 100%; }
    .hero-badge { display: inline-flex; align-items: center; gap: 0.5rem; background: rgba(255,214,0,0.12); border: 1px solid rgba(255,214,0,0.3); border-radius: var(--radius-xl); padding: 0.4rem 1.2rem; margin-bottom: 2rem; }
    .hero-badge-dot { width: 8px; height: 8px; background: var(--color-secondary); border-radius: 50%; animation: pulse 2s infinite; }
    @keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.5;transform:scale(0.8)} }
    .hero-badge span { font-family: var(--font-heading); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-secondary); }
    .hero-headline { font-size: clamp(3.5rem,9vw,8rem); font-weight: 900; line-height: 0.95; letter-spacing: -0.03em; margin-bottom: 2rem; }
    .hero-headline .line-accent { display: block; background: var(--grad-primary); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
    .hero-headline .line-yellow { display: block; color: var(--color-secondary); }
    .hero-sub { font-size: 1.15rem; color: rgba(255,255,255,0.7); max-width: 560px; margin-bottom: 2.5rem; line-height: 1.7; }
    .hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 4rem; }
    .hero-stats { display: flex; gap: 4rem; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.1); flex-wrap: wrap; }
    .stat-number { font-family: var(--font-display); font-size: 2.4rem; color: var(--color-secondary); display: block; }
    .stat-label { font-size: 0.78rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.5); }
    .hero-scroll { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 0.5rem; opacity: 0.5; }
    .scroll-line { width: 1px; height: 48px; background: linear-gradient(to bottom, rgba(255,255,255,0), rgba(255,255,255,0.7)); animation: scrollDown 2s ease-in-out infinite; }
    @keyframes scrollDown { 0%{transform:scaleY(0);transform-origin:top;opacity:0} 50%{transform:scaleY(1);opacity:1} 100%{transform:scaleY(0);transform-origin:bottom;opacity:0} }
    .scroll-text { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; writing-mode: vertical-rl; }

    /* MARQUEE */
    .marquee-strip { background: var(--color-secondary); padding: 0.8rem 0; overflow: hidden; }
    .marquee-track { display: flex; gap: 2rem; animation: marqueeScroll 25s linear infinite; white-space: nowrap; width: max-content; }
    .marquee-item { display: flex; align-items: center; gap: 1rem; font-family: var(--font-display); font-size: 1.1rem; letter-spacing: 0.08em; color: var(--color-dark); text-transform: uppercase; }
    .marquee-dot { width: 6px; height: 6px; background: var(--color-primary); border-radius: 50%; flex-shrink: 0; }
    @keyframes marqueeScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

    /* SECTION HEADER */
    .section-header { margin-bottom: 4rem; }
    .section-title { font-size: clamp(2rem,5vw,3.5rem); margin-top: 0.5rem; }
    .section-lead { font-size: 1.05rem; color: rgba(255,255,255,0.6); max-width: 560px; margin-top: 0.75rem; line-height: 1.7; }

    /* BRANDS */
    .brands-section { background: var(--color-mid); }
    .brands-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
    .brand-card { border-radius: var(--radius-lg); overflow: hidden; background: var(--color-dark); border: 1px solid rgba(255,255,255,0.07); transition: transform 0.3s, box-shadow 0.3s; display: flex; flex-direction: column; }
    .brand-card:hover { transform: translateY(-6px); box-shadow: 0 20px 60px rgba(0,0,0,0.4); }
    .brand-card-image { height: 200px; position: relative; display: flex; align-items: center; justify-content: center; }
    .brand-card.bounce   .brand-card-image { background: linear-gradient(135deg,#1a0a2e,#3d1a8a); }
    .brand-card.minigolf .brand-card-image { background: linear-gradient(135deg,#0a2e0a,#1a7a1a); }
    .brand-card.foam     .brand-card-image { background: linear-gradient(135deg,#001f3f,#0057b8); }
    .brand-card.funfair  .brand-card-image { background: linear-gradient(135deg,#2e1a00,#a85700); }
    .brand-card.choo     .brand-card-image { background: linear-gradient(135deg,#1a0a0a,#6b1a1a); }
    .brand-emoji { font-size: 5rem; filter: drop-shadow(0 8px 20px rgba(0,0,0,0.5)); transition: transform 0.3s; }
    .brand-card:hover .brand-emoji { transform: scale(1.15) rotate(-5deg); }
    .brand-card-badge { position: absolute; top: 1rem; right: 1rem; background: rgba(255,255,255,0.12); backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,0.2); border-radius: var(--radius-xl); padding: 0.3rem 0.8rem; font-family: var(--font-heading); font-size: 0.65rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; }
    .brand-card-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
    .brand-name { font-size: 1.2rem; font-weight: 800; margin-bottom: 0.5rem; line-height: 1.2; }
    .brand-desc { font-size: 0.88rem; color: rgba(255,255,255,0.6); line-height: 1.6; flex: 1; margin-bottom: 1.2rem; }
    .brand-regions { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 1.2rem; }
    .region-tag { background: rgba(0,194,255,0.12); border: 1px solid rgba(0,194,255,0.25); border-radius: var(--radius-xl); padding: 0.2rem 0.6rem; font-size: 0.65rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-accent); }
    .brand-link { display: inline-flex; align-items: center; gap: 0.4rem; font-family: var(--font-heading); font-size: 0.82rem; font-weight: 700; color: var(--color-secondary); transition: gap 0.2s; }
    .brand-link:hover { gap: 0.8rem; }
    .brand-card.featured { grid-column: span 2; flex-direction: row; }
    .brand-card.featured .brand-card-image { width: 300px; flex-shrink: 0; height: auto; }

    /* HOW IT WORKS */
    .how-section { background: var(--color-dark); position: relative; overflow: hidden; }
    .how-section::before { content:'FUN'; position:absolute; font-family:var(--font-display); font-size:20rem; color:rgba(255,255,255,0.025); right:-1rem; top:50%; transform:translateY(-50%); pointer-events:none; }
    .grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 2rem; }
    .steps-list { display: flex; flex-direction: column; position: relative; }
    .steps-list::before { content:''; position:absolute; left:2.2rem; top:0; bottom:0; width:2px; background:linear-gradient(to bottom,var(--color-primary),var(--color-accent)); }
    .step-item { display: flex; gap: 2rem; align-items: flex-start; padding: 2rem 0; }
    .step-icon { width: 4.5rem; height: 4.5rem; border-radius: 50%; background: var(--color-mid); border: 2px solid rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center; font-size: 1.6rem; flex-shrink: 0; position: relative; z-index: 1; transition: background 0.3s, border-color 0.3s; }
    .step-item:hover .step-icon { background: var(--color-primary); border-color: var(--color-primary); }
    .step-num { font-family: var(--font-display); font-size: 0.75rem; letter-spacing: 0.15em; color: var(--color-secondary); display: block; margin-bottom: 0.3rem; }
    .step-title { font-size: 1.3rem; margin-bottom: 0.4rem; }
    .step-desc { font-size: 0.9rem; color: rgba(255,255,255,0.6); line-height: 1.6; }

    /* AREAS */
    .areas-section { background: var(--color-mid); }
    .areas-visual { display: flex; gap: 2rem; }
    .area-card { flex: 1; background: var(--color-dark); border-radius: var(--radius-lg); padding: 2rem; border: 1px solid rgba(255,255,255,0.07); text-align: center; transition: transform 0.3s, border-color 0.3s; }
    .area-card:hover { transform: translateY(-4px); border-color: rgba(255,214,0,0.3); }
    .area-flag { font-size: 4rem; margin-bottom: 1rem; }
    .area-name { font-family: var(--font-display); font-size: 2rem; letter-spacing: 0.06em; color: var(--color-secondary); margin-bottom: 0.5rem; }
    .area-full { font-size: 0.85rem; color: rgba(255,255,255,0.5); margin-bottom: 1.2rem; }
    .area-brands { display: flex; flex-direction: column; gap: 0.5rem; }
    .area-brand-tag { background: rgba(255,255,255,0.05); border-radius: var(--radius-sm); padding: 0.5rem 0.75rem; font-size: 0.8rem; font-weight: 600; color: rgba(255,255,255,0.75); text-align: left; display: flex; align-items: center; gap: 0.5rem; }
    .area-brand-tag::before { content:'✓'; color: var(--color-accent); font-weight: 700; }

    /* TESTIMONIALS */
    .testimonials-section { background: var(--color-dark); }
    .testimonials-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }
    .testimonial-card { background: var(--color-mid); border-radius: var(--radius-lg); padding: 2rem; border: 1px solid rgba(255,255,255,0.06); position: relative; }
    .testimonial-card::before { content:'"'; position:absolute; top:-0.5rem; left:1.5rem; font-family:var(--font-display); font-size:5rem; color:var(--color-secondary); line-height:1; opacity:0.4; }
    .stars { display: flex; gap: 2px; margin-bottom: 0.75rem; font-size: 0.9rem; }
    .testimonial-text { font-size: 0.92rem; color: rgba(255,255,255,0.8); line-height: 1.7; margin-bottom: 1.25rem; }
    .testimonial-author { display: flex; align-items: center; gap: 0.75rem; }
    .author-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--grad-primary); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 0.9rem; flex-shrink: 0; }
    .author-name { font-weight: 700; font-size: 0.9rem; }
    .author-event { font-size: 0.75rem; color: rgba(255,255,255,0.45); }

    /* CTA */
    .cta-section { background: var(--grad-primary); position: relative; overflow: hidden; text-align: center; }
    .cta-section::before { content:''; position:absolute; inset:0; background-image:radial-gradient(circle,rgba(255,255,255,0.08) 1px,transparent 1px); background-size:30px 30px; }
    .cta-content { position: relative; z-index: 1; }
    .cta-title { font-size: clamp(2.2rem,6vw,4.5rem); font-weight: 900; margin-bottom: 1rem; }
    .cta-lead { font-size: 1.1rem; opacity: 0.85; margin-bottom: 2.5rem; max-width: 500px; margin-left: auto; margin-right: auto; }
    .cta-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

    /* FOOTER */
    .site-footer { background: #07070F; padding: 7rem 0 2rem; border-top: 1px solid rgba(255,255,255,0.05); }
    .footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 4rem; margin-bottom: 4rem; }
    .footer-logo-main { font-family: var(--font-display); font-size: 1.8rem; letter-spacing: 0.06em; color: var(--color-white); margin-bottom: 0.2rem; }
    .footer-logo-sub { font-family: var(--font-heading); font-size: 0.6rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-secondary); margin-bottom: 1rem; }
    .footer-about { font-size: 0.88rem; color: rgba(255,255,255,0.45); line-height: 1.7; margin-bottom: 1.5rem; }
    .footer-social { display: flex; gap: 0.75rem; }
    .social-btn { width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,0.07); display: flex; align-items: center; justify-content: center; font-size: 1rem; transition: background 0.2s, transform 0.2s; }
    .social-btn:hover { background: var(--color-primary); transform: translateY(-2px); }
    .footer-col-title { font-family: var(--font-heading); font-size: 0.75rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--color-secondary); margin-bottom: 1.2rem; }
    .footer-links { display: flex; flex-direction: column; gap: 0.6rem; }
    .footer-links a { font-size: 0.88rem; color: rgba(255,255,255,0.5); transition: color 0.2s; }
    .footer-links a:hover { color: var(--color-white); }
    .footer-bottom { display: flex; align-items: center; justify-content: space-between; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.06); flex-wrap: wrap; gap: 1rem; }
    .footer-copy { font-size: 0.8rem; color: rgba(255,255,255,0.3); }
    .footer-bottom-links { display: flex; gap: 1.5rem; }
    .footer-bottom-links a { font-size: 0.78rem; color: rgba(255,255,255,0.3); transition: color 0.2s; }
    .footer-bottom-links a:hover { color: rgba(255,255,255,0.7); }

    /* REVEAL */
    .reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.55s ease, transform 0.55s ease; }
    .reveal.visible { opacity: 1; transform: translateY(0); }

    @media(max-width:1024px) {
      .brands-grid { grid-template-columns: repeat(2,1fr); }
      .brand-card.featured { grid-column: span 2; flex-direction: column; }
      .brand-card.featured .brand-card-image { width: 100%; height: 220px; }
      .footer-grid { grid-template-columns: 1fr 1fr; }
      .testimonials-grid { grid-template-columns: 1fr 1fr; }
      .testimonials-grid .testimonial-card:last-child { grid-column: span 2; }
    }
    @media(max-width:768px) {
      .nav-menu { display: none; }
      .hamburger { display: flex; }
      .brands-grid { grid-template-columns: 1fr; }
      .brand-card.featured { grid-column: span 1; flex-direction: column; }
      .brand-card.featured .brand-card-image { width: 100%; height: 200px; }
      .grid-2 { grid-template-columns: 1fr; }
      .areas-visual { flex-direction: column; }
      .testimonials-grid { grid-template-columns: 1fr; }
      .testimonials-grid .testimonial-card:last-child { grid-column: span 1; }
      .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
      .footer-bottom { flex-direction: column; text-align: center; }
    }
    @media(prefers-reduced-motion:reduce) {
      .hero-blob,.marquee-track,.scroll-line,.hero-badge-dot { animation: none; }
      .reveal { opacity: 1; transform: none; }
    }
  
    /* QUOTE FORM */
    .quote-form-wrap {
      max-width: 780px;
      margin: 0 auto;
      background: rgba(255,255,255,0.1);
      backdrop-filter: blur(12px);
      border: 1px solid rgba(255,255,255,0.25);
      border-radius: var(--radius-lg);
      padding: 2.5rem;
      text-align: left;
    }
    .quote-form { display: flex; flex-direction: column; gap: 1.25rem; }
    .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
    .form-group { display: flex; flex-direction: column; gap: 0.4rem; }
    .form-group.full-width { grid-column: span 2; }
    .form-group label {
      font-family: var(--font-heading);
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: rgba(255,255,255,0.9);
    }
    .form-group input,
    .form-group select,
    .form-group textarea {
      background: rgba(255,255,255,0.15);
      border: 1px solid rgba(255,255,255,0.3);
      border-radius: var(--radius-sm);
      padding: 0.75rem 1rem;
      color: white;
      font-family: var(--font-body);
      font-size: 0.95rem;
      transition: border-color 0.2s, background 0.2s;
      outline: none;
      width: 100%;
    }
    .form-group input::placeholder,
    .form-group textarea::placeholder { color: rgba(255,255,255,0.45); }
    .form-group input:focus,
    .form-group select:focus,
    .form-group textarea:focus {
      border-color: rgba(255,255,255,0.7);
      background: rgba(255,255,255,0.2);
    }
    .form-group select option { background: #1E1E35; color: white; }
    .form-group input[type="date"]::-webkit-calendar-picker-indicator { filter: invert(1); opacity: 0.6; }
    .checkbox-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 0.6rem;
      margin-top: 0.25rem;
    }
    .checkbox-item {
      display: flex;
      align-items: center;
      gap: 0.6rem;
      font-size: 0.88rem;
      color: rgba(255,255,255,0.85);
      cursor: pointer;
      font-family: var(--font-body);
      text-transform: none;
      letter-spacing: 0;
      font-weight: 400;
    }
    .checkbox-item input[type="checkbox"] {
      width: 18px;
      height: 18px;
      flex-shrink: 0;
      accent-color: var(--color-secondary);
      cursor: pointer;
    }
    .form-submit {
      width: 100%;
      justify-content: center;
      font-size: 1.05rem;
      padding: 1rem 2rem;
      margin-top: 0.5rem;
    }
    .form-note {
      text-align: center;
      font-size: 0.78rem;
      color: rgba(255,255,255,0.55);
      margin-top: 0.25rem;
    }
    .form-success {
      display: none;
      text-align: center;
      padding: 2rem;
      background: rgba(255,255,255,0.15);
      border-radius: var(--radius-md);
      margin-top: 1rem;
    }
    .form-success span { font-size: 3rem; display: block; margin-bottom: 0.5rem; }
    .form-success h3 { font-size: 1.5rem; margin-bottom: 0.5rem; }
    .form-success p { color: rgba(255,255,255,0.8); font-size: 0.95rem; }

    @media(max-width:768px) {
      .form-row { grid-template-columns: 1fr; }
      .form-group.full-width { grid-column: span 1; }
      .checkbox-grid { grid-template-columns: 1fr; }
      .quote-form-wrap { padding: 1.5rem; }
    }

  