:root{
  --primary:#ff7686;
  --primary-light:#fff0f3;
  --primary-soft:#ffe7ec;
  --primary-hover:#f05e6f;
  --accent-purple:#9b72f8;
  --accent-gold:#f39c12;
  --accent-sage:#2ecc71;
  --accent-blue:#3498db;
  --accent-husband:#5b8dfc;
  --bg-app:linear-gradient(135deg,#fbf8f8 0%,#f4f0fa 100%);
  --sidebar-bg:rgba(255,255,255,.78);
  --card-bg:rgba(255,255,255,.82);
  --card-solid:#fff;
  --card-border:rgba(255,255,255,.58);
  --border-light:rgba(235,225,225,.82);
  --line:#eadfe3;
  --text-primary:#2c2527;
  --text-secondary:#605256;
  --text-muted:#958387;
  --danger:#dc4c3e;
  --green:#058527;
  --green-soft:#e6f4ea;
  --amber-soft:#fff3e0;
  --blue-soft:#e8f0fe;
  --purple-soft:#f1eafd;
  --shadow-sm:0 2px 8px rgba(220,200,200,.15);
  --shadow-md:0 8px 30px rgba(200,180,185,.20);
  --shadow-lg:0 16px 40px rgba(180,150,160,.25);
  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:24px;
  --transition:all .22s ease;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body,#app{height:100%}
body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Malgun Gothic",sans-serif;background:var(--bg-app);color:var(--text-primary);overflow:hidden;line-height:1.58;font-size:14px}
button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer}a{color:inherit}.hidden{display:none!important}
.app-container{height:100vh;width:100vw;display:flex;position:relative;overflow:hidden}
.sidebar{width:320px;min-width:320px;background:var(--sidebar-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border-light);display:flex;flex-direction:column;padding:24px;z-index:40;box-shadow:var(--shadow-sm)}
.sidebar-header{margin-bottom:20px}.app-logo{display:flex;align-items:center;gap:10px}.logo-icon{font-size:24px;animation:float 3s ease-in-out infinite}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}.logo-text{font-size:20px;font-weight:800;letter-spacing:-.6px;background:linear-gradient(135deg,var(--primary),var(--accent-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.logo-sub{font-size:11px;color:var(--text-muted);font-weight:700;margin-top:2px}
.due-date-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-sm);margin-bottom:18px;transition:var(--transition)}.due-date-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.card-row{display:flex;align-items:center;gap:12px}.baby-emoji{font-size:28px}.week-info{flex:1;min-width:0}.week-info h4{font-size:15px;letter-spacing:-.3px}.week-info p{font-size:12px;color:var(--text-secondary)}.baby-nickname-badge{display:inline-flex;margin-top:5px;padding:3px 9px;border-radius:999px;background:var(--primary-light);color:var(--primary-hover);font-size:11px;font-weight:800}.progress-container{display:flex;gap:8px;align-items:center;margin-top:12px}.progress-bar-wrapper{flex:1;height:7px;background:#f1e7eb;border-radius:99px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent-purple));border-radius:99px;transition:width .3s}.progress-pct{font-size:11px;font-weight:900;color:var(--primary-hover)}
.side-form{display:grid;grid-template-columns:1fr;gap:8px;margin-top:12px}.side-form label{font-size:11px;color:var(--text-muted);font-weight:800}.side-form input{width:100%;border:1px solid var(--line);background:rgba(255,255,255,.75);border-radius:10px;padding:9px 10px;outline:none}.side-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(255,118,134,.13)}
.sidebar-nav{flex:1;overflow:auto;padding-right:4px}.sidebar-nav::-webkit-scrollbar,.main-content::-webkit-scrollbar{width:8px}.sidebar-nav::-webkit-scrollbar-thumb,.main-content::-webkit-scrollbar-thumb{background:rgba(140,125,130,.22);border-radius:99px}.nav-section{margin-bottom:22px}.nav-section-title{display:block;font-size:11px;font-weight:900;color:var(--text-muted);letter-spacing:.02em;margin-bottom:8px;padding-left:4px}.nav-list{list-style:none;display:grid;gap:4px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;border:none;background:transparent;border-radius:12px;padding:10px 11px;color:var(--text-secondary);transition:var(--transition);text-align:left;font-weight:700}.nav-item:hover{background:rgba(255,255,255,.65);color:var(--text-primary)}.nav-item.active{background:var(--primary-light);color:var(--primary-hover);box-shadow:inset 0 0 0 1px rgba(255,118,134,.12)}.nav-item svg{width:18px;height:18px;stroke-width:2}.nav-badge{margin-left:auto;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:rgba(0,0,0,.05);display:grid;place-items:center;font-size:11px;color:var(--text-muted)}.nav-item.active .nav-badge{background:#fff;color:var(--primary-hover)}.sidebar-footer{border-top:1px solid var(--border-light);padding-top:14px;color:var(--text-muted);font-size:11px;display:flex;justify-content:space-between;gap:10px}.mobile-menu{display:none;border:none;background:var(--card-solid);border-radius:10px;padding:9px;box-shadow:var(--shadow-sm)}.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(44,37,39,.35);z-index:35}
.main-content{flex:1;min-width:0;height:100vh;overflow:auto}.content-header{position:sticky;top:0;z-index:25;background:rgba(251,248,248,.86);backdrop-filter:blur(16px);border-bottom:1px solid var(--border-light);padding:18px 32px;display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center}.header-left{display:flex;align-items:center;gap:13px;min-width:0}.header-titles{min-width:0}.header-left h1{font-size:24px;line-height:1.25;letter-spacing:-.7px}.view-subtitle{font-size:13px;color:var(--text-secondary);margin-top:3px}.header-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.search-box{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.8);border:1px solid var(--border-light);border-radius:999px;padding:8px 12px;min-width:250px}.search-box svg{width:16px;height:16px;color:var(--text-muted)}.search-box input{border:none;background:transparent;outline:none;width:100%;font-size:13px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--border-light);background:rgba(255,255,255,.86);border-radius:999px;padding:8px 13px;font-weight:900;font-size:13px;transition:var(--transition);min-height:37px}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-primary{border-color:transparent;background:linear-gradient(135deg,var(--primary),var(--accent-purple));color:#fff}.btn-danger{color:var(--danger)}.btn-sm{font-size:12px;padding:6px 10px;min-height:31px}.btn svg{width:15px;height:15px}.scroll-area{max-width:1260px;margin:0 auto;padding:28px 32px 80px}.notice{display:flex;gap:10px;align-items:flex-start;background:rgba(255,255,255,.72);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:14px 16px;color:var(--text-secondary);margin-bottom:18px}.notice strong{color:var(--text-primary)}
.card,.panel,.info-card,.subsidy-card,.gear-card,.diary-card,.comparison-card,.budget-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);backdrop-filter:blur(14px)}.panel{padding:22px;margin-bottom:18px}.section-title{font-size:18px;font-weight:900;letter-spacing:-.35px;margin-bottom:12px;display:flex;gap:8px;align-items:center}.section-desc{color:var(--text-secondary);font-size:13px;margin-top:-6px;margin-bottom:14px}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.metric-card{padding:16px;border-radius:18px;background:rgba(255,255,255,.7);border:1px solid var(--border-light)}.metric-label{font-size:11px;color:var(--text-muted);font-weight:900}.metric-value{font-size:24px;font-weight:950;letter-spacing:-.8px;margin-top:4px}.metric-caption{font-size:12px;color:var(--text-secondary);margin-top:3px}.tabs,.week-row,.chip-row{display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px}.tabs::-webkit-scrollbar,.week-row::-webkit-scrollbar,.chip-row::-webkit-scrollbar{height:6px}.tabs::-webkit-scrollbar-thumb,.week-row::-webkit-scrollbar-thumb,.chip-row::-webkit-scrollbar-thumb{background:rgba(0,0,0,.11);border-radius:99px}.tab,.week-badge,.chip{white-space:nowrap;border:1px solid var(--border-light);background:rgba(255,255,255,.85);border-radius:999px;padding:9px 14px;font-weight:900;color:var(--text-secondary);transition:var(--transition)}.tab.active,.week-badge.active,.chip.active{background:linear-gradient(135deg,var(--primary),var(--accent-purple));border-color:transparent;color:#fff;box-shadow:var(--shadow-sm)}.week-badge{width:48px;height:48px;display:grid;place-items:center;padding:0}.week-badge.current{box-shadow:0 0 0 3px rgba(255,118,134,.18)}.baby-message{display:flex;gap:14px;align-items:center;padding:22px;border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(255,240,243,.9),rgba(247,239,255,.9));border:1px solid rgba(255,118,134,.16);box-shadow:var(--shadow-md);margin-bottom:18px}.baby-face{width:58px;height:58px;border-radius:50%;background:#fff;display:grid;place-items:center;font-size:32px;box-shadow:var(--shadow-sm)}.baby-message small{font-weight:900;color:var(--primary-hover)}.baby-message p{font-size:16px;font-weight:800;letter-spacing:-.2px;margin-top:4px}.info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:18px}.info-card{padding:19px}.info-card .icon{width:38px;height:38px;border-radius:13px;background:var(--primary-light);display:grid;place-items:center;margin-bottom:11px}.info-card h3{font-size:15px;margin-bottom:7px}.info-card p{font-size:13px;color:var(--text-secondary)}
.task-list{display:grid;gap:9px}.task-item{display:grid;grid-template-columns:28px 1fr auto;gap:11px;align-items:start;padding:13px;border-radius:16px;background:rgba(255,255,255,.68);border:1px solid var(--border-light);transition:var(--transition)}.task-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);background:#fff}.task-check{width:24px;height:24px;border:2px solid #d7ccd0;border-radius:50%;display:grid;place-items:center;margin-top:1px;background:#fff;transition:var(--transition)}.task-check svg{width:14px;height:14px;opacity:0;color:#fff}.task-item.done .task-check{background:var(--accent-sage);border-color:var(--accent-sage)}.task-item.done .task-check svg{opacity:1}.task-title{font-weight:850;letter-spacing:-.2px}.task-item.done .task-title{text-decoration:line-through;color:var(--text-muted)}.task-note{font-size:12.5px;color:var(--text-secondary);margin-top:3px}.task-meta{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}.tag{display:inline-flex;align-items:center;gap:4px;border-radius:999px;padding:3px 8px;background:rgba(0,0,0,.045);color:var(--text-secondary);font-size:11px;font-weight:900}.tag.필수,.tag.priority-필수{background:#ffe8eb;color:#d73c50}.tag.권장,.tag.priority-권장{background:#fff3df;color:#a66400}.tag.선택,.tag.priority-선택{background:#e8f0fe;color:#2459bd}.tag.money{background:var(--green-soft);color:var(--green)}.tag.deadline{background:#ffe8eb;color:var(--danger)}.task-actions{display:flex;align-items:center;gap:5px}.empty{padding:50px 20px;text-align:center;color:var(--text-muted);background:rgba(255,255,255,.45);border:1px dashed var(--border-light);border-radius:var(--radius-lg)}.empty .big{font-size:34px;margin-bottom:8px}.stage-card{padding:20px;margin-bottom:16px}.stage-head{display:grid;grid-template-columns:1fr auto;gap:12px;margin-bottom:14px}.stage-title{font-size:20px;font-weight:950;letter-spacing:-.5px}.stage-period{font-size:12px;color:var(--text-muted);font-weight:900;margin-bottom:4px}.stage-summary{color:var(--text-secondary);font-size:13px}.stage-stat{font-size:12px;font-weight:900;color:var(--primary-hover);background:var(--primary-light);border-radius:999px;padding:6px 10px;align-self:start}.road-section{margin-top:16px}.road-section-title{font-size:15px;font-weight:950;border-bottom:1px solid var(--line);padding-bottom:8px;margin-bottom:9px}.tip{display:flex;gap:9px;background:rgba(255,243,224,.6);border:1px solid #f7dcc0;border-radius:14px;padding:11px 13px;color:#6b4b15;font-size:12.5px;margin-bottom:10px}.tip b{color:#46300c}.subsidy-grid,.gear-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.subsidy-card,.gear-card{padding:18px}.subsidy-head,.gear-head{display:flex;gap:12px;align-items:flex-start;margin-bottom:13px}.round-icon{width:44px;height:44px;border-radius:15px;background:var(--primary-light);display:grid;place-items:center;font-size:22px;flex:0 0 44px}.subsidy-card h3,.gear-card h3{font-size:17px;line-height:1.3;letter-spacing:-.3px}.amount{display:inline-flex;margin-top:6px;border-radius:999px;background:var(--green-soft);color:var(--green);font-size:12px;font-weight:950;padding:4px 9px}.sub-row{display:grid;grid-template-columns:88px 1fr;gap:8px;padding:7px 0;border-top:1px solid rgba(0,0,0,.055);font-size:12.5px}.sub-row .key{font-weight:950;color:var(--text-muted)}.html-detail{font-size:12.5px;color:var(--text-secondary);line-height:1.65}.html-detail strong{color:var(--text-primary)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field{display:grid;gap:6px}.field.full{grid-column:1/-1}.field label{font-size:12px;color:var(--text-muted);font-weight:950}.input,.select,.textarea{width:100%;border:1px solid var(--border-light);border-radius:13px;background:rgba(255,255,255,.76);padding:11px 12px;outline:none}.textarea{min-height:110px;resize:vertical}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(255,118,134,.13)}.table-wrap{overflow:auto;border:1px solid var(--border-light);border-radius:var(--radius-lg);background:rgba(255,255,255,.75)}table{width:100%;border-collapse:collapse;min-width:760px}th,td{border-bottom:1px solid var(--line);padding:10px;text-align:left;vertical-align:top;font-size:12.5px}th{background:rgba(255,240,243,.65);font-weight:950;color:var(--text-secondary);position:sticky;top:0}td input{width:100%;border:1px solid var(--border-light);border-radius:9px;padding:8px;background:#fff;outline:none}.budget-row{display:grid;grid-template-columns:1.3fr .8fr auto;gap:8px;align-items:center;margin-bottom:8px}.budget-row .input{text-align:right}.total-box{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:15px}.total-pill{border-radius:18px;background:rgba(255,255,255,.78);border:1px solid var(--border-light);padding:16px}.total-pill .label{font-size:12px;color:var(--text-muted);font-weight:950}.total-pill .value{font-size:23px;font-weight:950;margin-top:4px}.diary-list{display:grid;gap:12px;margin-top:16px}.diary-card{padding:16px}.diary-meta{display:flex;justify-content:space-between;gap:10px;color:var(--text-muted);font-size:12px;font-weight:800;margin-bottom:8px}.source-note{font-size:11px;color:var(--text-muted);margin-top:12px}.warning-list{display:grid;gap:8px;margin-top:10px}.warning-list li{list-style:none;padding:10px 12px;background:#fff5f5;border:1px solid #ffd7d7;border-radius:13px;color:#743232;font-size:13px}
.sync-status{display:grid;grid-template-columns:10px auto;grid-template-rows:auto auto;align-items:center;column-gap:7px;border:1px solid var(--border-light);background:rgba(255,255,255,.86);border-radius:16px;padding:6px 10px;min-height:42px;max-width:230px}.sync-dot{width:9px;height:9px;border-radius:50%;background:var(--accent-sage);grid-row:1/3}.sync-status span:not(.sync-dot){font-size:12px;font-weight:950;line-height:1.2}.sync-status small{font-size:10px;color:var(--text-muted);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sync-status.pending .sync-dot{background:var(--accent-gold);animation:pulse 1.2s ease-in-out infinite}.sync-status.error .sync-dot{background:var(--danger)}.sync-status.error span:not(.sync-dot){color:var(--danger)}@keyframes pulse{0%,100%{opacity:.45}50%{opacity:1}}
@media(max-width:1050px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.info-grid,.grid-3{grid-template-columns:1fr}.subsidy-grid,.gear-grid{grid-template-columns:1fr}.content-header{grid-template-columns:1fr}.header-right{justify-content:flex-start}.search-box{min-width:0;width:100%}.sync-status{max-width:none;width:100%}}
@media(max-width:900px){.sidebar{position:fixed;top:0;bottom:0;left:0;transform:translateX(-105%);transition:transform .25s ease}.app-container.side-open .sidebar{transform:translateX(0)}.app-container.side-open .mobile-overlay{display:block}.mobile-menu{display:inline-flex}.content-header{padding:14px 16px}.scroll-area{padding:20px 16px 70px}.header-left h1{font-size:20px}.form-grid,.grid-2,.total-box{grid-template-columns:1fr}.budget-row{grid-template-columns:1fr}.task-item{grid-template-columns:28px 1fr}.task-actions{grid-column:2}.sidebar{width:min(320px,88vw);min-width:0}}
@media(max-width:560px){body{font-size:13px}.metric-card{padding:13px}.grid-4{grid-template-columns:1fr}.baby-message{align-items:flex-start}.content-header{position:relative}.main-content{height:100vh}.scroll-area{padding-bottom:110px}}
