
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{
    --cream:#FBF8F5;
    --cream2:#F2ECF8;
    --green:#3D2070;
    --green-light:#5A3D99;
    --gold:#A07BC0;
    --gold-light:#D4B8E8;
    --blush:#F0E8F8;
    --text:#1E1628;
    --text-muted:#4A3860;
    --white:#FFFFFF;
    --border:#DDD0EC;
    --serif:'Cormorant Garamond',serif;
    --sans:'Nunito',sans-serif;
  }
  html{scroll-behavior:smooth}
  body{font-family:var(--sans);background:var(--cream);color:var(--text);min-height:100vh;padding-top:70px}
  .page{display:none;animation:fadeIn 0.4s ease}
  .page.active{display:block}
  @keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

  /* NAV */
  nav{position:fixed;top:0;left:0;right:0;z-index:9999;background:#FBF8F5;border-bottom:1px solid var(--border);padding:0 2rem}
  .nav-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:70px}
  .logo{font-family:var(--serif);font-size:1.8rem;font-weight:500;color:var(--green);cursor:pointer;letter-spacing:0.02em}
  .logo span{color:var(--gold)}
  .nav-links{display:flex;align-items:center;gap:0.25rem}
  .nav-links a{font-size:0.88rem;font-weight:500;color:var(--text-muted);text-decoration:none;padding:0.5rem 0.85rem;border-radius:20px;transition:all 0.2s;cursor:pointer;border:none;background:none;font-family:var(--sans)}
  .nav-links a:hover{color:var(--green);background:var(--cream2)}
  .nav-links a.active{color:var(--green);background:var(--cream2)}
  .nav-cta{background:var(--green)!important;color:var(--white)!important;padding:0.5rem 1.2rem!important;border-radius:25px!important}
  .nav-cta:hover{background:var(--green-light)!important}
  .mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;font-size:1.4rem;color:var(--green)}

  /* HERO */
  .hero{min-height:92vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;position:relative;overflow:hidden;background:var(--cream)}
  .hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 30%, #ede0f8 0%, transparent 70%);pointer-events:none}
  .hero-petal{position:absolute;opacity:0.18;pointer-events:none}
  .hero-petal.p1{top:8%;left:6%;width:180px}
  .hero-petal.p2{top:15%;right:5%;width:140px}
  .hero-petal.p3{bottom:12%;left:12%;width:120px}
  .hero-petal.p4{bottom:20%;right:8%;width:160px}
  .hero-content{position:relative;max-width:760px}
  .hero-badge{display:inline-block;background:var(--blush);color:var(--gold);font-size:0.78rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;padding:0.4rem 1.2rem;border-radius:20px;margin-bottom:1.5rem;border:1px solid var(--gold-light)}
  .hero h1{font-family:var(--serif);font-size:clamp(2.8rem,6vw,5rem);font-weight:300;line-height:1.15;color:var(--green);margin-bottom:1.2rem;letter-spacing:-0.01em}
  .hero h1 em{font-style:italic;color:var(--gold)}
  .hero-sub{font-size:1.12rem;color:var(--text-muted);line-height:1.7;max-width:560px;margin:0 auto 2.5rem;font-weight:400}
  .btn-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
  .btn-primary{background:var(--green);color:var(--white);padding:0.95rem 2.4rem;border-radius:30px;font-family:var(--sans);font-size:1rem;font-weight:700;border:none;cursor:pointer;transition:all 0.25s;letter-spacing:0.02em;min-height:52px}
  .btn-primary:hover{background:var(--green-light);transform:translateY(-1px)}
  .btn-outline{background:transparent;color:var(--green);padding:0.95rem 2.4rem;border-radius:30px;font-family:var(--sans);font-size:1rem;font-weight:700;border:2px solid var(--green);cursor:pointer;transition:all 0.25s;min-height:52px}
  .btn-outline:hover{background:var(--cream2);transform:translateY(-1px)}
  .hero-trust{margin-top:3rem;display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap}
  .trust-item{display:flex;align-items:center;gap:0.5rem;font-size:0.84rem;color:var(--text-muted)}
  .trust-icon{width:18px;height:18px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .trust-icon svg{width:10px;height:10px;stroke:white;fill:none}

  /* SECTION WRAPPER */
  .section{padding:5rem 2rem;max-width:1100px;margin:0 auto}
  .section-alt{background:var(--blush);padding:5rem 2rem}
  .section-alt .section{padding:0}
  .section-center{text-align:center}
  .section-label{font-size:0.78rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);margin-bottom:0.75rem}
  .section-title{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:400;color:var(--green);line-height:1.2;margin-bottom:1rem}
  .section-sub{font-size:1rem;color:var(--text-muted);line-height:1.7;max-width:600px}
  .section-sub.centered{margin:0 auto}

  /* FEATURES */
  .features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:3rem}
  .feature-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:2rem;transition:transform 0.2s,box-shadow 0.2s}
  .feature-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(43,68,56,0.08)}
  .feature-icon{width:48px;height:48px;background:var(--cream2);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;font-size:1.4rem}
  .feature-card h3{font-family:var(--serif);font-size:1.35rem;font-weight:500;color:var(--green);margin-bottom:0.6rem}
  .feature-card p{font-size:0.93rem;color:var(--text-muted);line-height:1.65}

  /* STEPS */
  .steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;margin-top:3.5rem;position:relative}
  .step-item{text-align:center;padding:1rem}
  .step-num{width:56px;height:56px;border-radius:50%;background:var(--green);color:var(--white);font-family:var(--serif);font-size:1.5rem;font-weight:500;display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem;position:relative;z-index:1}
  .step-item h3{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--green);margin-bottom:0.6rem}
  .step-item p{font-size:0.92rem;color:var(--text-muted);line-height:1.65}
  .step-connector{position:absolute;top:28px;left:calc(12.5% + 28px);right:calc(12.5% + 28px);height:2px;background:repeating-linear-gradient(90deg,var(--gold-light) 0,var(--gold-light) 6px,transparent 6px,transparent 14px);pointer-events:none;z-index:0}

  /* PRICING */
  .pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:3rem}
  .pricing-card{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:2.2rem;position:relative;transition:transform 0.2s}
  .pricing-card:hover{transform:translateY(-3px)}
  .pricing-card.featured{border:2px solid var(--green);background:var(--green)}
  .pricing-card.featured *:not(.pricing-badge){color:var(--white)!important}
  .pricing-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--white);font-size:0.75rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:0.3rem 1.1rem;border-radius:20px;white-space:nowrap}
  .pricing-tier{font-size:0.8rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);margin-bottom:0.5rem}
  .pricing-card.featured .pricing-tier{color:var(--gold-light)!important}
  .pricing-name{font-family:var(--serif);font-size:1.6rem;font-weight:500;color:var(--green);margin-bottom:0.5rem}
  .pricing-price{font-size:2.6rem;font-weight:600;color:var(--green);line-height:1}
  .pricing-price span{font-size:1rem;font-weight:400;color:var(--text-muted)}
  .pricing-desc{font-size:0.88rem;color:var(--text-muted);margin:0.8rem 0 1.5rem;line-height:1.6}
  .pricing-divider{border:none;border-top:1px solid var(--border);margin:1.5rem 0}
  .pricing-card.featured .pricing-divider{border-color:rgba(255,255,255,0.2)!important}
  .pricing-features{list-style:none;display:flex;flex-direction:column;gap:0.7rem;margin-bottom:2rem}
  .pricing-features li{font-size:0.9rem;color:var(--text-muted);display:flex;align-items:flex-start;gap:0.6rem;line-height:1.5}
  .pf-check{width:18px;height:18px;background:var(--cream2);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
  .pricing-card.featured .pf-check{background:rgba(255,255,255,0.2)!important}
  .pf-check::after{content:'✓';font-size:0.65rem;color:var(--green);font-weight:700}
  .pricing-card.featured .pf-check::after{color:white!important}
  .btn-pricing{width:100%;padding:0.85rem;border-radius:25px;font-family:var(--sans);font-size:0.93rem;font-weight:600;cursor:pointer;transition:all 0.2s;border:2px solid var(--green);background:transparent;color:var(--green)}
  .btn-pricing:hover{background:var(--green);color:var(--white)}
  .pricing-card.featured .btn-pricing{background:var(--white)!important;color:var(--green)!important;border-color:var(--white)!important}
  .pricing-card.featured .btn-pricing:hover{background:var(--cream2)!important}

  /* TESTIMONIALS */
  .testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:3rem}
  .testi-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:2rem;position:relative}
  .testi-card::before{content:'\201C';font-family:var(--serif);font-size:5rem;line-height:0.5;color:var(--gold-light);position:absolute;top:1.5rem;left:1.5rem;pointer-events:none}
  .testi-text{font-family:var(--serif);font-size:1.05rem;color:var(--text);line-height:1.75;font-style:italic;margin-bottom:1.5rem;padding-top:1.5rem}
  .testi-author{display:flex;align-items:center;gap:0.85rem}
  .testi-avatar{width:42px;height:42px;border-radius:50%;background:var(--cream2);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1rem;font-weight:500;color:var(--green);flex-shrink:0}
  .testi-name{font-weight:600;font-size:0.9rem;color:var(--green)}
  .testi-sub{font-size:0.8rem;color:var(--text-muted)}
  .stars{color:var(--gold);font-size:0.8rem;letter-spacing:2px;margin-bottom:0.3rem}

  /* UPLOAD PAGE */
  .upload-hero{background:var(--green);color:var(--white);padding:4rem 2rem;text-align:center}
  .upload-hero h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:300;margin-bottom:1rem}
  .upload-hero p{font-size:1rem;opacity:0.8;max-width:560px;margin:0 auto;line-height:1.7}
  .upload-form-wrap{max-width:700px;margin:3rem auto;padding:0 2rem 4rem}
  .form-section{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:2rem;margin-bottom:1.5rem}
  .form-section h3{font-family:var(--serif);font-size:1.4rem;font-weight:500;color:var(--green);margin-bottom:1.5rem;padding-bottom:0.75rem;border-bottom:1px solid var(--border)}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
  .form-row.full{grid-template-columns:1fr}
  .form-group{display:flex;flex-direction:column;gap:0.4rem}
  .form-group label{font-size:0.84rem;font-weight:600;color:var(--green);letter-spacing:0.02em}
  .form-group input,.form-group select,.form-group textarea{padding:0.7rem 1rem;border:1px solid var(--border);border-radius:10px;font-family:var(--sans);font-size:0.93rem;color:var(--text);background:var(--cream);transition:border-color 0.2s;outline:none}
  .form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green);background:var(--white)}
  .form-group textarea{resize:vertical;min-height:100px}
  .dropzone{border:2px dashed var(--gold-light);border-radius:16px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all 0.2s;background:var(--cream);position:relative}
  .dropzone:hover,.dropzone.drag-over{border-color:var(--gold);background:var(--blush)}
  .dropzone input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
  .dz-icon{font-size:2.5rem;margin-bottom:1rem}
  .dz-title{font-family:var(--serif);font-size:1.3rem;color:var(--green);margin-bottom:0.5rem}
  .dz-sub{font-size:0.85rem;color:var(--text-muted);line-height:1.6}
  .dz-types{display:flex;gap:0.5rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}
  .dz-type{background:var(--cream2);color:var(--text-muted);font-size:0.72rem;font-weight:600;padding:0.25rem 0.65rem;border-radius:10px;text-transform:uppercase;letter-spacing:0.06em}
  .file-list{margin-top:1rem;display:flex;flex-direction:column;gap:0.5rem}
  .file-item{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:0.6rem 1rem;display:flex;align-items:center;justify-content:space-between;font-size:0.85rem}
  .file-item-name{color:var(--green);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70%}
  .file-item-size{color:var(--text-muted);font-size:0.78rem}
  .btn-submit{width:100%;padding:1rem;background:var(--green);color:var(--white);border:none;border-radius:30px;font-family:var(--sans);font-size:1rem;font-weight:600;cursor:pointer;transition:all 0.25s;letter-spacing:0.03em}
  .btn-submit:hover{background:var(--green-light);transform:translateY(-1px)}
  .info-box{background:var(--blush);border:1px solid var(--gold-light);border-radius:12px;padding:1.2rem 1.5rem;margin-bottom:1.5rem;display:flex;gap:1rem;align-items:flex-start}
  .info-box-icon{font-size:1.2rem;flex-shrink:0}
  .info-box p{font-size:0.88rem;color:var(--text-muted);line-height:1.65}
  .info-box strong{color:var(--green);font-weight:600}

  /* PRIVATE AREA */
  .private-wrap{max-width:500px;margin:0 auto;padding:4rem 2rem}
  .login-card{background:var(--white);border:1px solid var(--border);border-radius:24px;padding:2.5rem;text-align:center}
  .login-card .lock-icon{width:64px;height:64px;background:var(--cream2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:1.8rem}
  .login-card h2{font-family:var(--serif);font-size:2rem;font-weight:400;color:var(--green);margin-bottom:0.5rem}
  .login-card p{font-size:0.9rem;color:var(--text-muted);margin-bottom:2rem;line-height:1.6}
  .download-area{display:none}
  .download-area.visible{display:block;animation:fadeIn 0.3s ease}
  .apk-card{background:var(--cream);border:1px solid var(--border);border-radius:16px;padding:1.5rem;margin-bottom:1rem;display:flex;align-items:center;gap:1.2rem;text-align:left}
  .apk-icon{width:52px;height:52px;background:var(--green);border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:white;font-size:1.5rem}
  .apk-name{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--green)}
  .apk-meta{font-size:0.8rem;color:var(--text-muted);margin-top:0.2rem}
  .apk-download{margin-left:auto;background:var(--green);color:var(--white);border:none;padding:0.6rem 1.2rem;border-radius:20px;font-family:var(--sans);font-size:0.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background 0.2s}
  .apk-download:hover{background:var(--green-light)}
  .welcome-name{font-family:var(--serif);font-size:1.3rem;color:var(--green);margin-bottom:0.5rem}

  /* FOOTER */
  footer{background:var(--green);color:rgba(255,255,255,0.7);padding:4rem 2rem 2rem;margin-top:0}
  .footer-inner{max-width:1100px;margin:0 auto}
  .footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
  .footer-brand .logo{color:var(--white)}
  .footer-brand .logo span{color:var(--gold-light)}
  .footer-brand p{font-size:0.88rem;margin-top:1rem;line-height:1.7;max-width:280px}
  .footer-col h4{font-size:0.78rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--white);font-weight:600;margin-bottom:1rem}
  .footer-col a{display:block;font-size:0.88rem;margin-bottom:0.5rem;color:rgba(255,255,255,0.6);text-decoration:none;cursor:pointer;transition:color 0.2s}
  .footer-col a:hover{color:var(--white)}
  .footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:2rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:gap}
  .footer-bottom p{font-size:0.82rem}

  /* ABOUT STRIP */
  .about-strip{background:var(--green);color:var(--white);padding:5rem 2rem;text-align:center}
  .about-strip h2{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:300;margin-bottom:1rem;max-width:700px;margin-left:auto;margin-right:auto;line-height:1.3}
  .about-strip p{font-size:0.98rem;opacity:0.75;max-width:560px;margin:0 auto 2rem;line-height:1.75}
  .about-stats{display:flex;gap:3rem;justify-content:center;flex-wrap:wrap;margin-top:3rem}
  .stat-item{text-align:center}
  .stat-num{font-family:var(--serif);font-size:2.8rem;font-weight:300;color:var(--gold-light)}
  .stat-label{font-size:0.82rem;opacity:0.65;letter-spacing:0.06em;text-transform:uppercase;margin-top:0.3rem}

  /* PROCESS DETAIL */
  .process-steps{display:flex;flex-direction:column;gap:0;margin-top:3rem}
  .process-step{display:grid;grid-template-columns:80px 1fr;gap:2rem;padding:2rem 0;border-bottom:1px solid var(--border)}
  .process-step:last-child{border-bottom:none}
  .ps-num{font-family:var(--serif);font-size:3.5rem;font-weight:300;color:var(--gold-light);line-height:1;text-align:center}
  .ps-content h3{font-family:var(--serif);font-size:1.4rem;font-weight:500;color:var(--green);margin-bottom:0.5rem}
  .ps-content p{font-size:0.93rem;color:var(--text-muted);line-height:1.7}
  .ps-tags{display:flex;gap:0.5rem;margin-top:0.75rem;flex-wrap:wrap}
  .ps-tag{background:var(--cream2);color:var(--text-muted);font-size:0.75rem;font-weight:600;padding:0.25rem 0.7rem;border-radius:20px}

  /* SUCCESS MESSAGE */
  .success-msg{background:var(--blush);border:1px solid var(--gold-light);border-radius:12px;padding:1.5rem;text-align:center;display:none}
  .success-msg.show{display:block;animation:fadeIn 0.3s ease}
  .success-msg .check{font-size:2rem;margin-bottom:0.5rem}
  .success-msg h3{font-family:var(--serif);font-size:1.4rem;color:var(--green);margin-bottom:0.5rem}
  .success-msg p{font-size:0.88rem;color:var(--text-muted);line-height:1.65}

  /* MEDIA QUERIES */
  @media(max-width:768px){
    .nav-links{display:none}
    .nav-links.open{display:flex;flex-direction:column;position:absolute;top:70px;left:0;right:0;background:rgba(251,248,245,0.98);border-bottom:1px solid var(--border);padding:0.75rem 1rem 1rem;gap:0.2rem;z-index:10000}
    .nav-links.open a{padding:0.75rem 1rem;border-radius:10px;font-size:0.95rem}
    .nav-links.open .nav-cta{margin-top:0.4rem;text-align:center;border-radius:25px!important}
    .mobile-menu-btn{display:block}
    .form-row{grid-template-columns:1fr}
    .footer-top{grid-template-columns:1fr 1fr}
    .step-connector{display:none}
    .hero{min-height:80vh;padding:3rem 1.25rem}
    .hero-trust{gap:1rem}
    .section{padding:3rem 1.25rem}
    .section-alt{padding:3rem 1.25rem}
    .how-grid{grid-template-columns:1fr!important;gap:2rem!important}
    .how-sticky{position:static!important}
    .features-grid{grid-template-columns:1fr}
    .pricing-grid{grid-template-columns:1fr}
    .testi-grid{grid-template-columns:1fr}
    .about-stats{gap:1.5rem}
    .process-step{grid-template-columns:60px 1fr;gap:1rem}
    .ps-num{font-size:2.5rem}
    .upload-form-wrap{padding:0 1.25rem 3rem}
    .apk-card{flex-wrap:wrap;gap:0.75rem}
    .apk-download{width:100%;text-align:center}
    .btn-row{flex-direction:column;align-items:center}
    .btn-row .btn-primary,.btn-row .btn-outline{width:100%;max-width:320px;text-align:center}
    .private-wrap{padding:2rem 1.25rem}
    .login-card{padding:1.75rem}
    .footer-top{grid-template-columns:1fr}
  }
  @media(max-width:520px){
    .footer-top{grid-template-columns:1fr}
    .hero h1{font-size:2.4rem}
    .pricing-price{font-size:2rem}
    .about-stats{flex-direction:column;gap:1.25rem}
  }

  /* ===== APP SHOWCASE ===== */
  .app-showcase-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2.5rem;margin-top:3rem}
  .app-showcase-card{display:flex;flex-direction:column;align-items:center;gap:1.5rem;background:var(--white);border:1px solid var(--border);border-radius:24px;padding:2rem;transition:transform 0.2s,box-shadow 0.2s}
  .app-showcase-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(61,32,112,0.12)}
  .app-phone-frame{width:180px;flex-shrink:0;background:#111;border-radius:28px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,0.35),0 0 0 2px #333;position:relative}
  .app-phone-frame img{width:100%;display:block}
  .app-showcase-info{text-align:center}
  .app-showcase-tag{display:inline-block;background:var(--blush);color:var(--gold);font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:0.3rem 0.85rem;border-radius:20px;margin-bottom:0.75rem;border:1px solid var(--gold-light)}
  .app-showcase-info h3{font-family:var(--serif);font-size:1.4rem;font-weight:500;color:var(--green);margin-bottom:0.5rem}
  .app-showcase-info p{font-size:0.88rem;color:var(--text-muted);line-height:1.65;margin-bottom:1rem}
  .app-showcase-features{display:flex;flex-wrap:wrap;gap:0.4rem;justify-content:center}
  .app-showcase-features span{background:var(--cream2);color:var(--text-muted);font-size:0.75rem;font-weight:600;padding:0.25rem 0.65rem;border-radius:12px}
  @media(max-width:768px){.app-phone-frame{width:150px}.app-showcase-card{padding:1.5rem}}

  /* ===== LEGAL / INFO PAGES ===== */
  .legal-wrap{max-width:780px;margin:0 auto;padding:3rem 2rem 5rem}
  .legal-wrap h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:300;color:var(--green);margin-bottom:0.5rem}
  .legal-wrap .last-updated{font-size:0.8rem;color:var(--text-muted);margin-bottom:2.5rem}
  .legal-wrap h2{font-family:var(--serif);font-size:1.4rem;font-weight:500;color:var(--green);margin:2rem 0 0.6rem}
  .legal-wrap p{font-size:0.93rem;color:var(--text-muted);line-height:1.8;margin-bottom:1rem}
  .legal-wrap ul{font-size:0.93rem;color:var(--text-muted);line-height:1.8;padding-left:1.5rem;margin-bottom:1rem}
  .legal-wrap ul li{margin-bottom:0.4rem}
  .legal-wrap a{color:var(--green);font-weight:600}
  .legal-hero{background:var(--blush);padding:4rem 2rem;text-align:center;border-bottom:1px solid var(--border)}
  .wizard-progress-wrap{background:var(--blush);border-bottom:1px solid var(--border);padding:1.5rem 2rem}
  .wizard-progress-inner{max-width:700px;margin:0 auto}
  .wizard-step-label{font-size:0.8rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--gold);margin-bottom:0.6rem}
  .wizard-bar-track{height:6px;background:var(--border);border-radius:10px;overflow:hidden;margin-bottom:1.2rem}
  .wizard-bar-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--green-light));border-radius:10px;transition:width 0.4s ease}
  .wizard-steps-dots{display:flex;gap:0.5rem;justify-content:space-between}
  .wdot{display:flex;flex-direction:column;align-items:center;gap:0.3rem;flex:1;cursor:default}
  .wdot span{width:32px;height:32px;border-radius:50%;background:var(--border);color:var(--text-muted);font-size:0.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all 0.3s}
  .wdot small{font-size:0.68rem;color:var(--text-muted);font-weight:600;letter-spacing:0.04em;text-transform:uppercase}
  .wdot.active span{background:var(--green);color:white}
  .wdot.done span{background:var(--gold);color:white}
  .wdot.active small,.wdot.done small{color:var(--green)}

  .wiz-step{display:none}
  .wiz-step.active{display:block;animation:fadeIn 0.35s ease}
  .wiz-nav{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding-bottom:3rem}

  /* ===== COLOUR PICKER ===== */
  .colour-picker-wrap{margin-bottom:1.25rem}
  .form-group-label{font-size:0.84rem;font-weight:600;color:var(--green);letter-spacing:0.02em;display:block;margin-bottom:0.4rem}
  .colour-picker-layout{display:flex;gap:1.5rem;align-items:flex-start;flex-wrap:wrap}
  .colour-wheel-container{position:relative;flex-shrink:0}
  #colourWheel{border-radius:50%;cursor:crosshair;display:block}
  .colour-picker-controls{flex:1;min-width:180px;display:flex;flex-direction:column;gap:0.75rem}
  .selected-preview-box{display:flex;align-items:center;gap:0.75rem;background:var(--cream2);border:1px solid var(--border);border-radius:10px;padding:0.75rem}
  .selected-preview-swatch{width:40px;height:40px;border-radius:8px;border:2px solid var(--border);background:#8B5CF6;flex-shrink:0}
  .chosen-colours{display:flex;gap:0.6rem;flex-wrap:wrap;margin-top:1rem;min-height:44px;align-items:center}
  .chosen-colours-empty{font-size:0.82rem;color:var(--text-muted);font-style:italic}
  .colour-chip{display:flex;align-items:center;gap:0.4rem;background:var(--white);border:1px solid var(--border);border-radius:20px;padding:0.3rem 0.7rem 0.3rem 0.4rem;font-size:0.8rem;font-weight:600;color:var(--text)}
  .colour-chip-dot{width:20px;height:20px;border-radius:50%;border:1px solid rgba(0,0,0,0.1);flex-shrink:0}
  .colour-chip-remove{background:none;border:none;cursor:pointer;font-size:0.75rem;color:var(--text-muted);margin-left:0.2rem;padding:0;line-height:1}
  .colour-chip-remove:hover{color:#c0392b}

  /* ===== INTEREST TAGS ===== */
  .interest-tags{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:0.5rem}
  .itag{background:var(--cream2);border:1.5px solid var(--border);color:var(--text-muted);font-size:0.83rem;font-weight:500;padding:0.4rem 0.85rem;border-radius:20px;cursor:pointer;transition:all 0.18s;user-select:none}
  .itag:hover{border-color:var(--green);color:var(--green)}
  .itag.selected{background:var(--green);border-color:var(--green);color:white}

  /* ===== PACKAGE SELECT ===== */
  .package-select-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:0.5rem}
  .pkg-card{border:2px solid var(--border);border-radius:16px;padding:1.4rem;cursor:pointer;transition:all 0.2s;position:relative;background:var(--white)}
  .pkg-card:hover{border-color:var(--green);transform:translateY(-2px)}
  .pkg-card.selected{border-color:var(--green);background:var(--cream2)}
  .pkg-card.featured{border-color:var(--green-light)}
  .pkg-card.featured.selected{background:var(--cream2)}
  .pkg-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:white;font-size:0.7rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:0.25rem 0.9rem;border-radius:20px;white-space:nowrap}
  .pkg-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);margin-bottom:0.75rem;transition:all 0.2s;position:relative}
  .pkg-card.selected .pkg-radio{border-color:var(--green);background:var(--green)}
  .pkg-card.selected .pkg-radio::after{content:'';position:absolute;inset:3px;background:white;border-radius:50%}
  #pkg-living .pkg-radio{border-color:rgba(212,184,232,0.9);background:rgba(255,255,255,0.12)}
  #pkg-living.selected .pkg-radio{border-color:#D4B8E8;background:#D4B8E8}
  #pkg-living.selected .pkg-radio::after{content:'';position:absolute;inset:3px;background:#1a0a3e;border-radius:50%}
  .pkg-name{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--green);margin-bottom:0.25rem}
  .pkg-price{font-size:1.8rem;font-weight:700;color:var(--green);margin-bottom:0.4rem}
  .pkg-desc{font-size:0.8rem;color:var(--text-muted);line-height:1.5;margin-bottom:0.75rem}
  .pkg-tags{display:flex;flex-wrap:wrap;gap:0.35rem}
  .pkg-tags span{background:var(--cream);color:var(--text-muted);font-size:0.7rem;font-weight:600;padding:0.2rem 0.55rem;border-radius:10px}

  /* ===== ADD-ONS ===== */
  .addon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:0.75rem}
  .addon-item{display:flex;gap:0.75rem;align-items:flex-start;background:var(--cream);border:1.5px solid var(--border);border-radius:12px;padding:1rem;cursor:pointer;transition:all 0.18s}
  .addon-item:hover{border-color:var(--green)}
  .addon-item input[type=checkbox]{margin-top:2px;accent-color:var(--green);flex-shrink:0}
  .addon-item input:checked ~ .addon-body .addon-name{color:var(--green)}
  .addon-body{flex:1}
  .addon-name{font-size:0.9rem;font-weight:600;color:var(--text);margin-bottom:0.15rem}
  .addon-price{font-size:0.85rem;font-weight:700;color:var(--gold);margin-bottom:0.2rem}
  .addon-desc{font-size:0.78rem;color:var(--text-muted);line-height:1.5}

  /* ===== ORDER SUMMARY ===== */
  .order-summary{background:var(--cream2);border:1px solid var(--border);border-radius:14px;padding:1.25rem 1.5rem;margin-top:1.5rem}
  .order-summary-title{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--green);margin-bottom:0.75rem}
  .order-line{display:flex;justify-content:space-between;font-size:0.88rem;color:var(--text-muted);padding:0.3rem 0;border-bottom:1px dashed var(--border)}
  .order-total{display:flex;justify-content:space-between;font-size:1.1rem;font-weight:700;color:var(--green);margin-top:0.75rem}

  /* ===== PAYMENT METHODS ===== */
  .payment-methods{display:flex;flex-direction:column;gap:0.6rem}
  .pay-method{display:flex;align-items:center;gap:0.75rem;background:var(--cream);border:1.5px solid var(--border);border-radius:12px;padding:1rem 1.25rem;cursor:pointer;transition:border-color 0.18s}
  .pay-method:has(input:checked){border-color:var(--green);background:var(--cream2)}
  .pay-body{display:flex;align-items:center;gap:0.75rem;flex:1}
  .pay-icon{font-size:1.4rem;flex-shrink:0}
  .pay-name{font-size:0.92rem;font-weight:600;color:var(--text)}
  .pay-sub{font-size:0.78rem;color:var(--text-muted);margin-top:0.1rem}
  .pay-method input[type=radio]{accent-color:var(--green);width:16px;height:16px;flex-shrink:0}

  @media(max-width:600px){
    .colour-picker-layout{flex-direction:column;align-items:center}
    .colour-picker-controls{width:100%}
    .wizard-steps-dots .wdot small{display:none}
    .package-select-grid{grid-template-columns:1fr}
    .addon-grid{grid-template-columns:1fr}
  }
