 {} *{} {} #IE-warning { display: none; position: fixed; width: 100%; height: 100%; z-index: 9999; background: white; } .IE-warning-message { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); text-align: center; } :root { --teal-dark: #073f46; --teal: #0f6f73; --teal-soft: #e6f4f3; --gold: #c9a24d; --cream: #fbf7ef; --charcoal: #1f2933; --muted: #637381; --white: #ffffff; --line: #e5e7eb; --shadow: 0 20px 60px rgba(7, 63, 70, 0.16); --radius: 22px; } * { box-sizing: border-box; } html { scroll-behavior: smooth; } body { margin: 0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif; color: var(--charcoal); background: var(--cream); line-height: 1.6; } a { color: inherit; text-decoration: none; } .container { width: min(1120px, 92%); margin: 0 auto; } .nav { position: sticky; top: 0; z-index: 20; background: rgba(251, 247, 239, 0.92); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(15, 111, 115, 0.12); } .nav-inner { display: flex; justify-content: space-between; align-items: center; padding: 16px 0; gap: 20px; } .brand { font-weight: 800; color: var(--teal-dark); line-height: 1.2; letter-spacing: -0.02em; } .brand span { display: block; font-size: 12px; font-weight: 500; color: var(--muted); margin-top: 2px; } .nav-links { display: flex; gap: 22px; align-items: center; font-size: 14px; color: var(--teal-dark); } .nav-cta { background: var(--teal-dark); color: var(--white); padding: 10px 16px; border-radius: 999px; font-weight: 700; } .hero { position: relative; overflow: hidden; background: radial-gradient(circle at 80% 10%, rgba(201,162,77,0.22), transparent 28%), linear-gradient(135deg, var(--teal-dark), #0b5960 58%, #0f7778); color: var(--white); padding: 88px 0 70px; } .hero::after { content: ""; position: absolute; inset: auto -10% -35% -10%; height: 260px; background: rgba(255,255,255,0.08); border-radius: 50% 50% 0 0; } .hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 44px; align-items: center; } .eyebrow { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.22); padding: 8px 12px; border-radius: 999px; font-size: 13px; margin-bottom: 20px; } h1 { margin: 0 0 18px; font-size: clamp(38px, 6vw, 68px); line-height: 0.98; letter-spacing: -0.055em; } .hero p { font-size: 19px; color: rgba(255,255,255,0.86); max-width: 620px; margin: 0 0 28px; } .hero-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; margin-top: 24px; } .btn { border: none; cursor: pointer; padding: 15px 22px; border-radius: 999px; font-weight: 800; font-size: 15px; transition: transform 0.2s ease, box-shadow 0.2s ease; display: inline-flex; align-items: center; justify-content: center; gap: 8px; } .btn:hover { transform: translateY(-2px); } .btn-primary { background: var(--gold); color: #1c1607; box-shadow: 0 12px 28px rgba(201,162,77,0.28); } .btn-secondary { background: rgba(255,255,255,0.12); color: var(--white); border: 1px solid rgba(255,255,255,0.28); } .hero-card { background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.22); border-radius: 30px; padding: 28px; box-shadow: var(--shadow); backdrop-filter: blur(16px); } .report-preview { background: var(--white); color: var(--charcoal); border-radius: 24px; padding: 24px; } .report-preview h3 { margin: 0 0 8px; color: var(--teal-dark); font-size: 24px; letter-spacing: -0.03em; } .score-circle { width: 128px; height: 128px; border-radius: 50%; background: conic-gradient(var(--teal) 0 76%, #e8eeee 76% 100%); display: grid; place-items: center; margin: 24px auto; } .score-inner { width: 94px; height: 94px; border-radius: 50%; background: var(--white); display: grid; place-items: center; text-align: center; color: var(--teal-dark); font-weight: 900; font-size: 28px; line-height: 1; } .score-inner span { display: block; font-size: 11px; color: var(--muted); margin-top: 5px; font-weight: 600; } .mini-list { display: grid; gap: 10px; margin-top: 16px; } .mini-item { display: flex; justify-content: space-between; gap: 12px; padding: 11px 12px; background: var(--teal-soft); border-radius: 14px; font-size: 14px; } .section { padding: 78px 0; } .section-title { max-width: 760px; margin: 0 auto 42px; text-align: center; } .section-title h2 { color: var(--teal-dark); font-size: clamp(30px, 4.5vw, 48px); line-height: 1.05; letter-spacing: -0.04em; margin: 0 0 14px; } .section-title p { color: var(--muted); font-size: 17px; margin: 0; } .grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; } .card { background: var(--white); border: 1px solid rgba(15,111,115,0.12); border-radius: var(--radius); padding: 26px; box-shadow: 0 12px 34px rgba(31, 41, 51, 0.06); } .icon { width: 44px; height: 44px; border-radius: 14px; background: var(--teal-soft); color: var(--teal-dark); display: grid; place-items: center; font-weight: 900; margin-bottom: 18px; } .card h3 { margin: 0 0 10px; color: var(--teal-dark); font-size: 21px; letter-spacing: -0.02em; } .card p { margin: 0; color: var(--muted); } .story { background: var(--white); } .story-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 44px; align-items: center; } .portrait-placeholder { min-height: 420px; border-radius: 30px; background: linear-gradient(135deg, rgba(15,111,115,0.88), rgba(7,63,70,0.94)), radial-gradient(circle at 30% 20%, rgba(201,162,77,0.32), transparent 32%); display: grid; place-items: center; color: var(--white); text-align: center; padding: 36px; box-shadow: var(--shadow); } .portrait-placeholder strong { display: block; font-size: 34px; letter-spacing: -0.04em; line-height: 1; margin-bottom: 12px; } .story h2 { color: var(--teal-dark); font-size: clamp(30px, 4vw, 48px); line-height: 1.08; letter-spacing: -0.04em; margin: 0 0 18px; } .story p { color: var(--muted); font-size: 17px; margin: 0 0 16px; } .quote { border-left: 4px solid var(--gold); padding-left: 18px; margin-top: 24px; color: var(--teal-dark); font-weight: 700; } .steps { background: radial-gradient(circle at 15% 20%, rgba(201,162,77,0.18), transparent 28%), var(--teal-soft); } .step-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; } .step { background: var(--white); border-radius: 20px; padding: 22px; border: 1px solid rgba(15,111,115,0.12); } .step-number { color: var(--gold); font-size: 13px; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 8px; } .testimonial-band { background: var(--teal-dark); color: var(--white); padding: 68px 0; } .testimonial { max-width: 860px; margin: 0 auto; text-align: center; } .testimonial p { font-size: clamp(22px, 3vw, 34px); line-height: 1.25; letter-spacing: -0.035em; margin: 0 0 20px; } .testimonial span { color: rgba(255,255,255,0.7); } .contact { background: var(--cream); padding: 86px 0; } .contact-box { background: var(--white); border-radius: 32px; box-shadow: var(--shadow); padding: 44px; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 34px; align-items: center; border: 1px solid rgba(15,111,115,0.12); } .contact-box h2 { margin: 0 0 16px; color: var(--teal-dark); font-size: clamp(30px, 4.5vw, 48px); line-height: 1.05; letter-spacing: -0.04em; } .contact-box p { color: var(--muted); font-size: 17px; margin: 0 0 20px; } .contact-details { display: grid; gap: 10px; margin-top: 20px; color: var(--teal-dark); font-weight: 700; } .report-card-small { background: var(--teal-soft); border-radius: 24px; padding: 26px; } .report-card-small ul { padding-left: 20px; margin: 14px 0 0; color: var(--charcoal); } .footer { background: #062f35; color: rgba(255,255,255,0.78); padding: 28px 0; font-size: 13px; text-align: center; } /* Modal */ .modal-overlay { position: fixed; inset: 0; background: rgba(6, 47, 53, 0.72); z-index: 100; display: none; align-items: center; justify-content: center; padding: 18px; } .modal-overlay.active { display: flex; } .modal { width: min(620px, 100%); background: var(--white); border-radius: 28px; box-shadow: 0 30px 100px rgba(0,0,0,0.28); overflow: hidden; animation: modalIn 0.25s ease; } @keyframes modalIn { from { opacity: 0; transform: translateY(18px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } } .modal-header { background: radial-gradient(circle at 90% 5%, rgba(201,162,77,0.32), transparent 28%), linear-gradient(135deg, var(--teal-dark), var(--teal)); color: var(--white); padding: 24px 26px; display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; } .modal-header h3 { margin: 0; font-size: 23px; letter-spacing: -0.03em; line-height: 1.15; } .modal-header p { margin: 8px 0 0; color: rgba(255,255,255,0.78); font-size: 14px; } .close-btn { border: 1px solid rgba(255,255,255,0.25); background: rgba(255,255,255,0.12); color: white; width: 36px; height: 36px; border-radius: 999px; cursor: pointer; font-size: 20px; line-height: 1; } .modal-body { padding: 26px; } .progress-wrap { margin-bottom: 20px; } .progress-label { display: flex; justify-content: space-between; font-size: 12px; color: var(--muted); margin-bottom: 8px; } .progress-bar { height: 8px; background: #edf1f1; border-radius: 999px; overflow: hidden; } .progress-fill { height: 100%; width: 0%; background: var(--teal); border-radius: 999px; transition: width 0.3s ease; } .question-title { font-size: 22px; line-height: 1.25; letter-spacing: -0.03em; color: var(--teal-dark); margin: 0 0 16px; font-weight: 900; } .question-sub { color: var(--muted); margin: -6px 0 18px; font-size: 14px; } .answer-list { display: grid; gap: 10px; } .answer-btn { width: 100%; text-align: left; background: #f7fbfb; border: 1px solid #d9e7e7; color: var(--charcoal); padding: 14px 15px; border-radius: 16px; cursor: pointer; font-size: 15px; line-height: 1.35; transition: all 0.18s ease; } .answer-btn:hover { background: var(--teal-soft); border-color: var(--teal); transform: translateY(-1px); } .answer-btn strong { color: var(--teal-dark); margin-right: 6px; } .input-field { width: 100%; border: 1px solid #d9e7e7; border-radius: 16px; padding: 15px 16px; font-size: 16px; outline: none; } .input-field:focus { border-color: var(--teal); box-shadow: 0 0 0 4px rgba(15,111,115,0.12); } .contact-input-grid { display: grid; gap: 12px; } .input-label { display: block; font-size: 13px; color: var(--teal-dark); font-weight: 800; margin-bottom: 6px; } .modal-actions { display: flex; justify-content: space-between; gap: 12px; margin-top: 20px; } .btn-modal { border: none; border-radius: 999px; padding: 13px 18px; font-weight: 800; cursor: pointer; } .btn-back { background: #edf1f1; color: var(--teal-dark); } .btn-next { background: var(--teal-dark); color: var(--white); margin-left: auto; } .summary-box { background: var(--teal-soft); border-radius: 20px; padding: 18px; margin: 16px 0; } .summary-score { font-size: 42px; line-height: 1; font-weight: 900; color: var(--teal-dark); letter-spacing: -0.04em; } .summary-score span { font-size: 15px; color: var(--muted); font-weight: 700; } .summary-circle-wrap { display: grid; place-items: center; margin: 20px 0 18px; } .summary-score-circle { width: 150px; height: 150px; border-radius: 50%; display: grid; place-items: center; box-shadow: 0 16px 36px rgba(7, 63, 70, 0.18); } .summary-score-circle-inner { width: 108px; height: 108px; border-radius: 50%; background: var(--white); display: grid; place-items: center; text-align: center; color: var(--teal-dark); font-weight: 900; font-size: 34px; line-height: 1; } .summary-score-circle-inner span { display: block; font-size: 12px; color: var(--muted); margin-top: 5px; font-weight: 700; } .whatsapp-final-btn { width: 100%; background: #25D366; color: #08351f; font-weight: 900; margin-top: 18px; } .summary-note { color: var(--muted); font-size: 14px; margin: 12px 0 0; text-align: center; } .debug-box { display: none; background: #f3f4f6; border-radius: 16px; padding: 14px; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; font-size: 12px; color: #374151; overflow: auto; max-height: 220px; margin-top: 14px; } @media (max-width: 900px) { .hero-grid, .story-grid, .contact-box { grid-template-columns: 1fr; } .grid-3, .step-row { grid-template-columns: 1fr 1fr; } .nav-links { display: none; } } @media (max-width: 620px) { .hero { padding: 62px 0 52px; } .grid-3, .step-row { grid-template-columns: 1fr; } .contact-box { padding: 28px; } .modal-body { padding: 22px; } .modal-header { padding: 22px; } .btn { width: 100%; } .hero-actions { width: 100%; } }
