 {} *{} {} #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 { --bg-dark: #06101b; --bg-deep: #071522; --panel-dark: #0c1a2c; --teal: #02d1d1; --teal-soft: #56c7c7; --teal-dark: #0f4f4f; --gold: #c8a45d; --gold-soft: #f0d79d; --cream: #fbf7ef; --sand: #f2eadb; --paper: #fffdf8; --ink: #1f2a2a; --muted: #6b7474; --line: #e5dccb; --risk: #9a3d36; --warn: #8a5a10; --ok: #216045; --risk-bg: #fff0ef; --warn-bg: #fff4df; --ok-bg: #eaf6f0; --shadow: 0 18px 45px rgba(15, 79, 79, .12); --radius: 22px; --radius-lg: 28px; --max: 1120px; } @property --outline-angle { syntax: "<angle>"; initial-value: 0deg; inherits: false; } @keyframes hero-outline-spin { to { --outline-angle: 360deg; } } * { box-sizing: border-box; } html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; } body { margin: 0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif; color: var(--ink); line-height: 1.5; overflow-wrap: anywhere; background: linear-gradient(115deg, rgba(251,247,239,1) 0%, rgba(253,250,244,1) 38%, rgba(237,247,244,1) 72%, rgba(255,255,255,1) 100%); background-attachment: fixed; } body::before { content: "CONNIE TAN PROPERTIES"; position: fixed; right: -10vw; top: 12vh; transform: rotate(-18deg); font-size: clamp(44px, 10vw, 126px); font-weight: 900; letter-spacing: .08em; color: rgba(15, 79, 79, .032); pointer-events: none; white-space: nowrap; z-index: 0; } .page { position: relative; z-index: 1; width: min(var(--max), calc(100% - 32px)); margin: 0 auto; padding: 24px 0 56px; } /* HERO */ .hero-wrap { background: linear-gradient(135deg, #06101b 0%, #081929 58%, #06101b 100%); border-radius: 32px; padding: clamp(24px, 4vw, 44px); box-shadow: 0 22px 55px rgba(0,0,0,.18); position: relative; overflow: hidden; border: 1px solid rgba(255,255,255,.08); } .hero-wrap::before { content: ""; position: absolute; top: -115px; right: -100px; width: 340px; height: 340px; border-radius: 999px; background: radial-gradient(circle at center, rgba(2, 209, 209, .28) 0%, rgba(2, 209, 209, .17) 34%, rgba(12, 65, 88, .16) 58%, transparent 74%); filter: blur(1px); pointer-events: none; } .hero-wrap > * { position: relative; z-index: 1; } .logo-area { display: flex; justify-content: center; align-items: center; margin: 0 auto 26px; text-align: center; } .brand-logo { width: min(360px, 78vw); height: auto; display: block; filter: drop-shadow(0 16px 28px rgba(0,0,0,.35)); } .hero { background: rgba(14, 29, 50, .82); color: #fff; border-radius: 28px; padding: clamp(22px, 4vw, 38px); position: relative; overflow: hidden; border: 1px solid rgba(86,199,199,.26); box-shadow: 0 22px 50px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255,255,255,.08); } .hero-pill { position: relative; display: inline-flex; align-items: center; width: fit-content; max-width: 100%; padding: 9px 16px; margin-bottom: 18px; border-radius: 999px; font-size: 13px; letter-spacing: .03em; font-weight: 700; color: #bdf5f4; background: rgba(3, 17, 29, .62); backdrop-filter: blur(10px); overflow: hidden; isolation: isolate; box-shadow: inset 0 0 18px rgba(255,255,255,.08), 0 0 18px rgba(86,199,199,.12); white-space: normal; z-index: 2; } .hero-pill span { position: relative; z-index: 3; } .hero-pill::before { content: ""; position: absolute; inset: 0; padding: 2px; border-radius: inherit; background: conic-gradient( from var(--outline-angle), transparent 0deg, transparent 210deg, rgba(255,255,255,1) 255deg, rgba(240,215,157,1) 290deg, rgba(2,209,209,1) 320deg, transparent 350deg, transparent 360deg ); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; animation: hero-outline-spin 2.6s linear infinite; pointer-events: none; } .hero-pill::after { content: ""; position: absolute; inset: 2px; border-radius: inherit; background: rgba(0, 0, 0, .20); box-shadow: inset 0 0 20px rgba(255,255,255,.12), 0 0 16px rgba(255,255,255,.12); pointer-events: none; z-index: -1; } .hero h1 { margin: 0 0 16px; max-width: 880px; color: #ffffff; font-size: clamp(36px, 6vw, 66px); line-height: 1.04; letter-spacing: -.045em; text-shadow: 0 2px 18px rgba(0,0,0,.24); } .hero p { margin: 10px 0; max-width: 860px; color: rgba(236,245,247,.82); font-size: clamp(16px, 2vw, 21px); } .hero .small { margin-top: 18px; color: rgba(236,245,247,.66); font-size: 13px; } /* SECTIONS */ .section { margin-top: 26px; background: rgba(255,253,248,.96); border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: clamp(18px, 3vw, 30px); overflow: hidden; } .eyebrow { color: var(--gold); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; font-weight: 900; margin-bottom: 8px; } h2 { margin: 0 0 16px; color: var(--teal-dark); font-size: clamp(26px, 3.8vw, 40px); line-height: 1.15; letter-spacing: -.03em; } h3 { margin: 22px 0 10px; color: var(--teal-dark); font-size: clamp(19px, 2.5vw, 27px); line-height: 1.2; letter-spacing: -.02em; } h4 { margin: 0 0 8px; color: var(--teal-dark); font-size: 17px; } p { margin: 8px 0; } .grid { display: grid; gap: 16px; } .grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); } .grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); } .grid.four { grid-template-columns: repeat(4, minmax(0, 1fr)); } .card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 20px; box-shadow: 0 12px 30px rgba(31,42,42,.06); min-width: 0; overflow-wrap: anywhere; } .card.soft { background: radial-gradient(circle at top right, rgba(200,164,93,.12), transparent 38%), linear-gradient(135deg, #fff, #fff7e8); } .label { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; font-weight: 800; margin-bottom: 6px; min-height: 32px; display: flex; align-items: flex-start; } .kpi { margin-top: 5px; color: var(--teal-dark); font-size: clamp(27px, 4.4vw, 44px); font-weight: 900; line-height: 1.05; letter-spacing: -.03em; overflow-wrap: normal; word-break: keep-all; } .small { font-size: 13px; color: var(--muted); } .mini { display: block; margin-top: 4px; color: var(--muted); font-size: 12px; line-height: 1.35; } .note, .warning { margin: 16px 0; padding: 15px 16px; border-radius: 16px; overflow-wrap: anywhere; } .note { background: #fff7e8; border-left: 5px solid var(--gold); } .warning { background: #fff0ef; border-left: 5px solid #b7724b; } /* TABLES — no horizontal scroll, mobile/PDF ready */ .table-box { width: 100%; margin: 14px 0 18px; } table { width: 100%; max-width: 100%; border-collapse: separate; border-spacing: 0; border: 1px solid var(--line); border-radius: 18px; overflow: hidden; background: #fff; table-layout: fixed; font-size: 14px; } th, td { padding: 12px 12px; border-bottom: 1px solid var(--line); vertical-align: top; white-space: normal; overflow-wrap: anywhere; word-break: normal; hyphens: auto; } th { background: var(--sand); color: var(--teal-dark); text-align: left; font-size: 13px; font-weight: 900; } tr:last-child td { border-bottom: 0; } td.num, th.num { text-align: right; font-variant-numeric: tabular-nums; white-space: normal; overflow-wrap: normal; word-break: keep-all; } .strong-row td { background: #fffaf1; color: var(--teal-dark); font-weight: 900; } .dash { color: #9b9b9b; font-weight: 900; } .table-2col th:first-child, .table-2col td:first-child { width: 68%; } .table-2col th:last-child, .table-2col td:last-child { width: 32%; } .table-income th:nth-child(1), .table-income td:nth-child(1) { width: 40%; } .table-income th:nth-child(2), .table-income td:nth-child(2) { width: 20%; } .table-income th:nth-child(3), .table-income td:nth-child(3) { width: 15%; } .table-income th:nth-child(4), .table-income td:nth-child(4) { width: 25%; } .table-route th:nth-child(1), .table-route td:nth-child(1) { width: 20%; } .table-route th:nth-child(2), .table-route td:nth-child(2), .table-route th:nth-child(3), .table-route td:nth-child(3), .table-route th:nth-child(4), .table-route td:nth-child(4) { width: 26.66%; } .table-mortgage th:nth-child(1), .table-mortgage td:nth-child(1) { width: 24%; } .table-mortgage th:nth-child(2), .table-mortgage td:nth-child(2), .table-mortgage th:nth-child(3), .table-mortgage td:nth-child(3), .table-mortgage th:nth-child(4), .table-mortgage td:nth-child(4), .table-mortgage th:nth-child(5), .table-mortgage td:nth-child(5) { width: 19%; } .score-risk { background: #fff4f2; color: var(--risk); font-weight: 800; } .score-warn { background: #fff8e8; color: var(--warn); font-weight: 800; } .score-neutral { background: #f7f5ef; color: var(--teal-dark); font-weight: 800; } /* CAPACITY CARDS */ .capacity-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin-top: 12px; } .capacity-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; box-shadow: 0 12px 30px rgba(31,42,42,.05); min-width: 0; } .capacity-card.combined { grid-column: 1 / -1; background: radial-gradient(circle at top right, rgba(200,164,93,.14), transparent 40%), linear-gradient(135deg, #fff, #fff7e8); } .capacity-amount { margin: 6px 0; color: var(--teal-dark); font-size: clamp(23px, 3.4vw, 36px); line-height: 1.05; font-weight: 900; letter-spacing: -.035em; white-space: nowrap; overflow: hidden; text-overflow: clip; } .decision-band { margin-top: 20px; padding: 22px; border-radius: var(--radius); background: radial-gradient(circle at top right, rgba(2,209,209,.16), transparent 34%), linear-gradient(135deg, #06101b, #0c1a2c); color: #fff; border: 1px solid rgba(86,199,199,.16); } .decision-band h3 { margin-top: 0; color: #fff; } .decision-band p { color: rgba(236,245,247,.82); } .checklist { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin-top: 14px; } .check { background: #fffaf1; border: 1px solid var(--line); border-radius: 16px; padding: 14px 15px; font-size: 14px; min-width: 0; overflow-wrap: anywhere; } .check strong { color: var(--teal-dark); } .footer { margin-top: 30px; padding-top: 18px; border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; text-align: center; } .avoid-break { break-inside: avoid; page-break-inside: avoid; } @media (max-width: 900px) { .page { width: min(100% - 24px, var(--max)); padding-top: 14px; } .grid.three, .grid.two { grid-template-columns: 1fr; } .grid.four { grid-template-columns: repeat(2, minmax(0, 1fr)); } .hero-wrap { padding: 24px; } .section { padding: 18px; } .card { padding: 17px; } table { font-size: 12.2px; } th, td { padding: 10px 8px; } } @media (max-width: 680px) { body::before { display: none; } .page { width: min(100% - 18px, var(--max)); } .hero-wrap { border-radius: 24px; padding: 18px; } .hero-wrap::before { top: -95px; right: -95px; width: 260px; height: 260px; } .logo-area { margin-bottom: 20px; } .brand-logo { width: min(330px, 82vw); } .hero { border-radius: 22px; padding: 22px; } .hero-pill { padding: 8px 12px; font-size: 12px; } .hero h1 { font-size: clamp(34px, 9.5vw, 52px); } .hero p { font-size: 15.5px; } .section { margin-top: 18px; padding: 16px; border-radius: 22px; } .grid.four { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; } .card { padding: 13px; border-radius: 18px; } .label { font-size: 10px; letter-spacing: .07em; min-height: 42px; } .kpi { font-size: clamp(22px, 7.2vw, 34px); } .capacity-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; } .capacity-card { padding: 13px; border-radius: 18px; } .capacity-card h4 { font-size: 14px; } .capacity-amount { font-size: clamp(17px, 5.2vw, 23px); letter-spacing: -.045em; } .capacity-card p { font-size: 12px; } .capacity-card.combined { grid-column: 1 / -1; } table { font-size: 10.2px; border-radius: 16px; } th, td { padding: 8px 5px; line-height: 1.35; } th { font-size: 9.7px; } .table-income th:nth-child(1), .table-income td:nth-child(1) { width: 39%; } .table-income th:nth-child(2), .table-income td:nth-child(2) { width: 20%; } .table-income th:nth-child(3), .table-income td:nth-child(3) { width: 14%; } .table-income th:nth-child(4), .table-income td:nth-child(4) { width: 27%; } .small, .mini { font-size: 10.5px; line-height: 1.35; } .checklist { grid-template-columns: 1fr; } } @media (max-width: 390px) { .grid.four { gap: 10px; } .card { padding: 11px; } .label { min-height: 44px; } .kpi { font-size: 21px; } .capacity-grid { grid-template-columns: 1fr; } .capacity-card.combined { grid-column: auto; } .capacity-amount { font-size: 22px; } table { font-size: 9.4px; } th, td { padding: 7px 4px; line-height: 1.3; } th { font-size: 9px; } } @media print { * { -webkit-print-color-adjust: exact; print-color-adjust: exact; } body { background: #fff; } body::before { display: none; } .page { width: 100%; max-width: none; padding: 0; } .hero-wrap, .hero, .section, .card, .capacity-card, .decision-band { box-shadow: none; } .hero-wrap { background: #06101b !important; } .hero { background: rgba(14, 29, 50, .92) !important; } .hero-pill { color: #bdf5f4 !important; background: rgba(3, 17, 29, .78) !important; border: 1.5px solid rgba(240, 215, 157, .88) !important; box-shadow: none !important; overflow: visible !important; } .hero-pill span { position: relative; z-index: 3; color: #bdf5f4 !important; } .hero-pill::before, .hero-pill::after { content: none !important; display: none !important; animation: none !important; background: none !important; -webkit-mask: none !important; mask: none !important; -webkit-mask-composite: initial !important; mask-composite: initial !important; } .section, .hero, .hero-wrap, .card, .capacity-card, table { break-inside: avoid; page-break-inside: avoid; } table { table-layout: fixed; width: 100%; font-size: 9.8px; } th, td { padding: 6px 5px; line-height: 1.25; } a { color: inherit; text-decoration: none; } }
