/* ════════════════════════════════════
   SOOFT Design System v2
   실제 앱 코드에서 추출한 색상 토큰 기반
   ════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* ── Shared ── */
  --bg:#09090b;--surface:#111113;--surface2:#1c1c1f;--surface3:#27272a;
  --text:#fafafa;--text2:#a1a1aa;--text3:#71717a;
  --border:rgba(255,255,255,.06);
  --radius:20px;--radius-sm:14px;--radius-xs:10px;

  /* ── CheckMate (AppTheme.swift 기반) ── */
  --cm:#E8622A;--cm-soft:rgba(232,98,42,.12);--cm-bg:#1C1917;--cm-surface:#292524;
  --cm-text1:#F5F0EB;--cm-text2:#A8A098;--cm-text3:#6B6358;
  --cm-green:#2DB87A;--cm-green-l:#1A2E22;--cm-amber:#D4A020;--cm-amber-l:#2E2810;

  /* ── GRide (DesignSystem.swift 기반) ── */
  --gr:#00E87A;--gr-soft:rgba(0,232,122,.12);--gr-bg:#0A0A0A;--gr-card:#141414;
  --gr-border:#1E1E1E;--gr-ghost:#FF4444;--gr-hr:#EF9F27;--gr-power:#FF8C44;
  --gr-run:#4488FF;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);overflow-x:hidden;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  -webkit-font-smoothing:antialiased;line-height:1.5}
a{text-decoration:none;color:inherit}img{display:block;max-width:100%}

/* ── Layout ── */
.container{max-width:1120px;margin:0 auto;padding:0 24px}
.section{padding:120px 0}
@media(max-width:768px){.section{padding:80px 0}}

/* ── Type ── */
.label{font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--text3);margin-bottom:14px}
.title{font-size:clamp(32px,5vw,56px);font-weight:800;letter-spacing:-2px;line-height:1.08;margin-bottom:20px}
.desc{font-size:16px;color:var(--text2);line-height:1.7;max-width:520px}
.grad-text{background:linear-gradient(135deg,var(--cm),var(--gr));-webkit-background-clip:text;-webkit-text-fill-color:transparent}

/* ── Animations ── */
.fade-in{opacity:0;transform:translateY(36px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.fade-in.visible{opacity:1;transform:translateY(0)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ── Nav ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  background:rgba(9,9,11,.72);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1120px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:60px}
.logo{font-size:19px;font-weight:800;letter-spacing:-.5px}
.logo span{background:linear-gradient(135deg,var(--cm),var(--gr));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.nav-links{display:flex;gap:28px}
.nav-links a{font-size:13px;color:var(--text2);font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--text)}

/* ── Hero (Index) ── */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden;padding:100px 24px 80px}
.hero-content{position:relative;z-index:1}
.hero-badge{display:inline-block;padding:6px 16px;border-radius:100px;font-size:12px;font-weight:600;color:var(--text2);background:var(--surface2);border:1px solid var(--border);margin-bottom:28px}
.hero h1{font-size:clamp(44px,8vw,84px);font-weight:900;letter-spacing:-3px;line-height:.94;margin-bottom:24px}
.hero-desc{font-size:clamp(15px,1.8vw,18px);color:var(--text2);max-width:520px;margin:0 auto 44px;line-height:1.7}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-glow{position:absolute;top:-20%;left:50%;transform:translateX(-50%);width:700px;height:700px;
  background:radial-gradient(circle,rgba(232,98,42,.1) 0%,rgba(0,232,122,.07) 50%,transparent 70%);pointer-events:none}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 30px;border-radius:100px;font-size:14px;font-weight:600;transition:transform .2s,box-shadow .2s;cursor:pointer;border:none}
.btn:hover{transform:translateY(-2px)}
.btn-cm{background:var(--cm);color:#fff}.btn-cm:hover{box-shadow:0 8px 30px rgba(232,98,42,.3)}
.btn-gr{background:var(--gr);color:#0A0A0A}.btn-gr:hover{box-shadow:0 8px 30px rgba(0,232,122,.3)}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-outline:hover{border-color:rgba(255,255,255,.2);background:var(--surface2)}
.btn-lg{padding:16px 36px;font-size:16px;font-weight:700}

/* ── App Grid (Index) ── */
.app-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:56px}
@media(max-width:768px){.app-grid{grid-template-columns:1fr}}
.app-card{display:block;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;position:relative;transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s}
.app-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.4)}
.card-glow{position:absolute;top:0;left:0;right:0;height:180px;pointer-events:none}
.cm .card-glow{background:linear-gradient(180deg,rgba(232,98,42,.08) 0%,transparent 100%)}
.gr .card-glow{background:linear-gradient(180deg,rgba(0,232,122,.08) 0%,transparent 100%)}
.card-body{position:relative;z-index:1;padding:40px 36px 36px}
.app-icon{width:64px;height:64px;border-radius:15px;margin-bottom:20px;box-shadow:0 6px 20px rgba(0,0,0,.3)}
.card-body h3{font-size:28px;font-weight:800;letter-spacing:-.5px;margin-bottom:10px}
.card-body>p{font-size:15px;color:var(--text2);line-height:1.6;margin-bottom:24px}
.card-link{font-size:14px;font-weight:600;color:var(--text2);transition:color .2s}
.app-card:hover .card-link{color:var(--text)}
.app-card.cm:hover .card-link{color:var(--cm)}
.app-card.gr:hover .card-link{color:var(--gr)}
.badge{display:inline-block;padding:5px 12px;border-radius:100px;font-size:11px;font-weight:600;margin-bottom:20px}
.badge-cm{background:var(--cm-soft);color:var(--cm)}
.badge-gr{background:var(--gr-soft);color:var(--gr)}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}
.tags span{padding:5px 12px;border-radius:100px;font-size:11px;font-weight:500;background:var(--surface2);color:var(--text2);border:1px solid var(--border)}

/* ── About ── */
.about-wrap{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
@media(max-width:768px){.about-wrap{grid-template-columns:1fr;gap:48px}}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.stat{background:var(--surface2);border-radius:var(--radius-sm);padding:28px;text-align:center;border:1px solid var(--border)}
.stat-num{font-size:34px;font-weight:800;margin-bottom:4px;background:linear-gradient(135deg,var(--cm),var(--gr));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-label{font-size:12px;color:var(--text3);font-weight:500}

/* ── Footer ── */
footer{border-top:1px solid var(--border);padding:36px 0}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-copy{font-size:12px;color:var(--text3)}
.footer-links{display:flex;gap:20px}
.footer-links a{font-size:12px;color:var(--text3);transition:color .2s}
.footer-links a:hover{color:var(--text)}

/* ════════════════════════════════════
   Detail Pages
   ════════════════════════════════════ */

/* ── Detail Hero ── */
.detail-hero{padding:140px 0 100px;position:relative;overflow:hidden}
.detail-hero .container{position:relative;z-index:1}
.detail-hero .app-icon-lg{width:88px;height:88px;border-radius:22px;box-shadow:0 12px 40px rgba(0,0,0,.4);margin-bottom:24px}
.detail-hero h1{font-size:clamp(40px,6vw,64px);font-weight:900;letter-spacing:-2px;line-height:1;margin-bottom:16px}
.detail-hero .hero-desc{max-width:560px;margin-bottom:36px}

/* ── Feature Sections ── */
.feat-section{padding:100px 0;position:relative}
.feat-section:nth-child(even){background:var(--surface)}
.feat-wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.feat-wrap.reverse{direction:rtl}.feat-wrap.reverse>*{direction:ltr}
@media(max-width:768px){.feat-wrap{grid-template-columns:1fr;gap:40px}.feat-wrap.reverse{direction:ltr}}
.feat-text .feat-num{font-size:11px;font-weight:700;letter-spacing:2px;margin-bottom:12px}
.feat-text h3{font-size:clamp(28px,4vw,40px);font-weight:800;letter-spacing:-1px;line-height:1.1;margin-bottom:16px}
.feat-text>p{font-size:15px;color:var(--text2);line-height:1.7;margin-bottom:24px}
.feat-highlights{display:flex;flex-direction:column;gap:10px;list-style:none}
.feat-highlights li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text2)}
.feat-highlights .dot{width:6px;height:6px;border-radius:50%;margin-top:7px;flex-shrink:0}
.cm-page .dot{background:var(--cm)}.gr-page .dot{background:var(--gr)}

/* ── Phone Mockup (실제 앱 색상 기반) ── */
.phone-wrap{display:flex;justify-content:center}
.phone{width:280px;height:560px;border-radius:40px;border:3px solid rgba(255,255,255,.08);overflow:hidden;position:relative;box-shadow:0 24px 80px rgba(0,0,0,.5)}
.phone .notch{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:100px;height:30px;background:#000;border-radius:16px;z-index:2}
.phone .screen{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;padding:56px 14px 14px;overflow:hidden}
/* CheckMate 폰 배경: 실제 AppTheme bg */
.cm-phone{background:var(--cm-bg)}
/* GRide 폰 배경: 실제 DesignSystem bg */
.gr-phone{background:var(--gr-bg)}

/* ── 앱 내부 UI 컴포넌트 (실제 코드 기반) ── */

/* CheckMate 내부 요소 */
.cm-card{background:var(--cm-surface);border-radius:12px;padding:10px 12px;border:0.5px solid rgba(245,240,235,.05)}
.cm-card-title{font-size:11px;font-weight:600;color:var(--cm-text1)}
.cm-card-sub{font-size:8px;color:var(--cm-text2);margin-top:2px}
.cm-label{font-size:8px;color:var(--cm-text3);font-weight:500}
.cm-ring{width:40px;height:40px;border-radius:50%;border:3px solid var(--cm-surface);position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cm-priority-bar{width:3px;border-radius:2px;align-self:stretch;flex-shrink:0}
.cm-tab{display:inline-block;padding:4px 12px;border-radius:8px;font-size:9px;font-weight:600}
.cm-tab-active{background:var(--cm-text1);color:var(--cm-bg)}
.cm-tab-inactive{color:var(--cm-text1)}
.cm-input-bar{display:flex;align-items:center;gap:6px;background:var(--cm-surface);border-radius:22px;padding:8px 12px;border:0.5px solid rgba(245,240,235,.05)}

/* GRide 내부 요소 */
.gr-card{background:var(--gr-card);border-radius:12px;padding:10px 12px;border:0.5px solid var(--gr-border)}
.gr-stat{text-align:center}
.gr-stat-val{font-size:18px;font-weight:800}
.gr-stat-label{font-size:7px;color:#444;font-weight:500;margin-top:1px}
.gr-stat-unit{font-size:6px;color:#444}
.gr-tab{display:inline-block;padding:4px 10px;border-radius:6px;font-size:9px;font-weight:600}
.gr-tab-active{background:var(--gr);color:var(--gr-bg)}
.gr-tab-inactive{color:#666}

/* ── Bento Features ── */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:56px}
@media(max-width:768px){.bento{grid-template-columns:1fr}}
.bento-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:28px;transition:border-color .3s}
.bento-card:hover{border-color:rgba(255,255,255,.12)}
.bento-icon{font-size:28px;margin-bottom:14px}
.bento-card h4{font-size:16px;font-weight:700;margin-bottom:8px}
.bento-card p{font-size:13px;color:var(--text2);line-height:1.6}

/* ── CTA Section ── */
.cta-section{text-align:center;padding:120px 24px;position:relative}
.cta-section h2{font-size:clamp(32px,5vw,52px);font-weight:800;letter-spacing:-2px;margin-bottom:14px}
.cta-section p{color:var(--text2);font-size:16px;margin-bottom:36px}

/* ── Pricing ── */
.tier-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:48px}
@media(max-width:768px){.tier-grid{grid-template-columns:1fr}}
.tier-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:36px}
.tier-card.featured{border-color:var(--gr)}
.tier-card .tier-name{font-size:14px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.tier-card .tier-price{font-size:36px;font-weight:800;margin-bottom:4px}
.tier-card .tier-period{font-size:13px;color:var(--text3);margin-bottom:20px}
.tier-card ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.tier-card ul li{font-size:13px;color:var(--text2);display:flex;align-items:center;gap:8px}
.tier-card ul li::before{content:'✓';font-weight:700;font-size:12px}
.cm-page .tier-card ul li::before{color:var(--cm)}
.gr-page .tier-card ul li::before{color:var(--gr)}
