:root{--bg: #0b1220;--bg-soft: #16223a;--surface: #ffffff;--surface-alt: #f4f7fb;--text: #0f172a;--text-muted: #5b6b82;--border: #e3e9f2;--primary: #2563eb;--primary-dark: #1d4ed8;--primary-soft: #eaf1fe;--accent: #0ea5e9;--success: #16a34a;--warning: #f59e0b;--danger: #dc2626;--radius: 16px;--radius-sm: 10px;--shadow-sm: 0 1px 2px rgba(2, 6, 23, .05), 0 1px 6px rgba(2, 6, 23, .04);--shadow: 0 4px 10px rgba(2, 6, 23, .05), 0 16px 36px -12px rgba(2, 6, 23, .14);--ring: 0 0 0 3px rgba(37, 99, 235, .22);font-family:Pretendard Variable,Pretendard,Segoe UI,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;color:var(--text);background:radial-gradient(1100px 380px at 85% -120px,rgba(37,99,235,.07),transparent 60%),radial-gradient(900px 320px at -10% -80px,rgba(14,165,233,.06),transparent 55%),var(--surface-alt);-webkit-font-smoothing:antialiased;letter-spacing:-.01em}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit;font-size:.95rem}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:6px}.app{display:flex;flex-direction:column;min-height:100vh}.nav{position:sticky;top:0;z-index:50;background:#0b1220db;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;padding:12px 28px;display:flex;align-items:center;gap:20px;box-shadow:0 1px #ffffff0f,0 12px 30px -18px #020617b3}.nav .logo{font-weight:800;font-size:1.12rem;letter-spacing:-.02em;white-space:nowrap;background:linear-gradient(90deg,#fff 30%,#93c5fd);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.nav-links{display:flex;align-items:center;gap:4px;overflow-x:auto;scrollbar-width:none}.nav-links::-webkit-scrollbar{display:none}.nav a{color:#b9c4d6;font-size:.92rem;font-weight:500;padding:7px 13px;border-radius:999px;white-space:nowrap;transition:color .15s ease,background-color .15s ease}.nav a:hover{color:#fff;text-decoration:none;background:#ffffff12}.nav a.active{color:#fff;font-weight:650;background:#60a5fa2e}.nav-right{margin-left:auto}.container{max-width:1060px;margin:0 auto;padding:34px 28px 48px;width:100%;flex:1}.card{background:var(--surface);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.card+.card,.card+.feature-grid,.feature-grid+.card{margin-top:20px}h1{margin:0 0 8px;font-size:1.7rem;font-weight:800;letter-spacing:-.03em}h2{margin:0 0 14px;font-size:1.28rem;font-weight:750;letter-spacing:-.02em}h3{letter-spacing:-.02em}section.card>h2:before,section.card>h1:before{content:"";display:inline-block;width:5px;height:1em;margin-right:10px;border-radius:4px;background:linear-gradient(180deg,var(--primary),var(--accent));vertical-align:-.14em}p.lead{color:var(--text-muted);margin:0 0 24px;line-height:1.65}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:.83rem;font-weight:600;color:var(--text-muted)}.field input,.field select{height:44px;padding:0 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;color:var(--text);background:#fbfdff;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.field input::placeholder{color:#9aa8bd}.field input:hover,.field select:hover{border-color:#c8d4e6}.field input:focus,.field select:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:var(--ring)}.actions{margin-top:22px;display:flex;gap:10px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:0;border-radius:var(--radius-sm);height:46px;padding:0 24px;font-weight:650;letter-spacing:-.01em;box-shadow:0 6px 16px -8px #2563eb8c;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}.btn:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 10px 22px -8px #2563eb99}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn.secondary{background:#fff;color:var(--primary);border:1.5px solid #c7d8f8;box-shadow:none}.btn.secondary:hover{background:var(--primary-soft);filter:none}.result{position:relative;overflow:hidden;background:linear-gradient(135deg,#f0f6ff,#e7f3fe 55%,#e5f6fd);border-radius:var(--radius);padding:30px;border:1px solid #cfe2fb;margin-top:22px;box-shadow:var(--shadow-sm)}.result:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--primary),var(--accent))}.result .headline{font-size:2.7rem;font-weight:850;letter-spacing:-.03em;margin:2px 0 0;background:linear-gradient(120deg,var(--primary-dark),var(--accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.result .ci{color:var(--text-muted);font-size:.92rem;margin-top:4px}.result table{margin-top:16px;width:100%;border-collapse:collapse;font-size:.9rem}.result table td{padding:8px;border-bottom:1px solid rgba(15,23,42,.06)}.result table td:first-child{color:var(--text-muted);width:42%}.result ul.notes{margin:14px 0 0;padding-left:18px;color:var(--text-muted);font-size:.88rem;line-height:1.6}.upload{border:2px dashed #c4d2e6;border-radius:var(--radius);padding:30px 24px;text-align:center;background:linear-gradient(180deg,#fbfdff,#f6f9fd);transition:border-color .15s ease,background-color .15s ease,transform .15s ease}.upload:hover{border-color:#93b4ee}.upload input[type=file]{display:block;margin:12px auto 0;color:var(--text-muted);font-size:.88rem}.upload.drag{border-color:var(--primary);background:var(--primary-soft);transform:scale(1.005)}.badge{display:inline-block;padding:3px 11px;border-radius:999px;font-size:.74rem;font-weight:700;letter-spacing:0;background:#dbeafe;color:#1e40af;margin-left:8px;vertical-align:middle}.badge.bone{background:#ede9fe;color:#5b21b6}.badge.parental{background:#ccfbf1;color:#0f766e}.pill{display:inline-block;padding:3px 11px;border-radius:999px;font-size:.76rem;font-weight:700}.pill.danger{background:#fee2e2;color:#b91c1c}.pill.ok{background:#dcfce7;color:#15803d}.footer{text-align:center;padding:26px 16px;color:#8294ac;font-size:.82rem;line-height:1.6}.error{color:var(--danger);background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);padding:10px 14px;font-size:.9rem;margin-top:14px;white-space:pre-line;line-height:1.5}.warning-banner{background:#fffaeb;border:1px solid #fde68a;border-left:4px solid #d97706;border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:14px}.warning-banner h4{margin:0 0 6px;color:#92400e;font-size:1rem}.warning-banner ul{margin:4px 0 8px 18px;padding:0;color:#78350f;font-size:.9rem}.warning-banner .action{display:inline-block;background:#d97706;color:#fff;padding:6px 12px;border-radius:6px;font-size:.85rem;font-weight:600;margin-top:4px}.override-hint{background:var(--primary-soft);border-left:3px solid var(--primary);padding:8px 12px;border-radius:6px;font-size:.85rem;color:#1e3a8a;margin-top:6px;line-height:1.5}.hero{position:relative;overflow:hidden;background:radial-gradient(620px 240px at 88% -40px,rgba(56,189,248,.28),transparent 60%),radial-gradient(420px 220px at 8% 110%,rgba(37,99,235,.35),transparent 62%),linear-gradient(135deg,#122348,#1e3a8a 55%,#1d4ed8);color:#fff;border-radius:20px;padding:52px 44px;margin-bottom:24px;box-shadow:var(--shadow)}.hero-badge{display:inline-block;font-size:.78rem;font-weight:650;letter-spacing:.02em;color:#bfdbfe;background:#93c5fd24;border:1px solid rgba(147,197,253,.35);padding:5px 13px;border-radius:999px;margin-bottom:16px}.hero h1{font-size:2.3rem;line-height:1.25;margin-bottom:12px}.hero h1 .hl{background:linear-gradient(90deg,#7dd3fc,#a5b4fc);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero p{opacity:.88;max-width:600px;margin:0;line-height:1.7;font-size:.97rem}.hero .cta-row{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}.hero .cta-row a{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--primary-dark);padding:12px 22px;border-radius:var(--radius-sm);font-weight:700;box-shadow:0 10px 26px -10px #0206178c;transition:transform .15s ease,box-shadow .15s ease}.hero .cta-row a:hover{text-decoration:none;transform:translateY(-1px);box-shadow:0 14px 30px -10px #02061799}.hero .cta-row a.ghost{background:#ffffff14;border:1px solid rgba(255,255,255,.45);color:#fff;box-shadow:none}.hero .cta-row a.ghost:hover{background:#ffffff29}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px}.feature{display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.feature:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:#cfdcf4}.feature .feature-icon{width:46px;height:46px;display:flex;align-items:center;justify-content:center;font-size:1.45rem;border-radius:12px;background:var(--primary-soft);margin-bottom:14px}.feature h3{margin:0 0 8px;font-size:1.08rem}.feature p{color:var(--text-muted);font-size:.92rem;line-height:1.65;margin:0 0 10px}.feature ul{margin:0 0 16px;padding-left:18px;color:var(--text-muted);font-size:.85rem;line-height:1.7}.feature .card-link{margin-top:auto;font-weight:700;font-size:.92rem}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:6px}.step{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px}.step .step-no{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-size:.82rem;font-weight:800;margin-bottom:10px}.step b{display:block;margin-bottom:4px;letter-spacing:-.01em}.step p{margin:0;color:var(--text-muted);font-size:.86rem;line-height:1.6}.disclaimer{margin:20px 0 0;padding:12px 16px;background:#fffaeb;border:1px solid #fde68a;border-radius:var(--radius-sm);color:#92400e;font-size:.85rem;line-height:1.6}.auth-wrap{max-width:430px;margin:36px auto 0}.data-grid{width:100%;border-collapse:collapse;font-size:.89rem;margin-top:8px}.data-grid th,.data-grid td{padding:11px 13px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;vertical-align:middle}.data-grid th{position:sticky;top:0;color:var(--text-muted);font-weight:700;font-size:.76rem;letter-spacing:.03em;background:var(--surface-alt);z-index:1}.data-grid th:first-child{border-top-left-radius:8px}.data-grid th:last-child{border-top-right-radius:8px}.data-grid tbody tr{transition:background-color .12s ease}.data-grid tbody tr:nth-child(2n){background:#fafcff}.data-grid tbody tr:hover{background:var(--primary-soft)}.data-grid img{display:block;transition:transform .15s ease}.data-grid a:hover img{transform:scale(1.06)}@media (max-width: 760px){.container{padding:20px 16px 40px}.nav{padding:10px 14px;gap:10px}.nav .logo{font-size:1rem}.nav a{padding:6px 10px;font-size:.86rem}.card{padding:20px;border-radius:14px}.hero{padding:34px 24px;border-radius:16px}.hero h1{font-size:1.6rem}.result{padding:22px 18px}.result .headline{font-size:2.1rem}.data-grid{font-size:.82rem}.data-grid th,.data-grid td{padding:9px 10px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{transition:none!important;animation:none!important}}
