/* assets/css/components.css */
/* Navbar */
  .nav{
    position:sticky; top:0; z-index:10;
    background:var(--card);
    backdrop-filter:saturate(160%) blur(8px);
    border-bottom:var(--pen-stroke);
    box-shadow:0 2px 0 0 var(--ink);
  }
  .nav-inner{
    max-width:1100px; margin:0 auto;
    display:flex; align-items:center; gap:14px;
    padding:12px 16px;
  }
  .brand{display:flex; align-items:center; gap:10px; font-weight:1000}
  .brand .logo{
    width:34px; height:34px; border-radius:10px;
    display:grid; place-items:center;
    background:#fff;
    border:var(--pen-stroke);
    box-shadow:var(--pen-shadow);
  }
  .nav-links{display:flex; gap:10px; margin-left:8px}
  .nav-links a{
    padding:8px 10px; border-radius:10px;
    color:var(--muted); font-weight:950; font-size:14px;
  }
  .nav-links a.active{color:var(--ink); background:#e8eef7}
  .chip{
    display:flex; align-items:center; gap:8px;
    padding:8px 10px; border:var(--pen-stroke);
    border-radius:999px; background:#fff;
    font-weight:950; font-size:14px;
    color:var(--ink);
    box-shadow:var(--pen-shadow);
  }
  a.chip{ text-decoration:none; cursor:pointer; }
  a.chip:hover{ color:var(--ink); }
  button.chip{ border:var(--pen-stroke); cursor:pointer; font:inherit; }
  button.chip:hover{ color:var(--ink); }
  .chip-avatar{ width:26px; height:26px; border-radius:50%; object-fit:cover; flex-shrink:0; }
  .dot{width:8px; height:8px; border-radius:50%; background:var(--success)}
  
  /* Hero - 단색 배경 + 볼펜 테두리 */
  .hero{
    margin-top:16px;
    border:var(--pen-stroke);
    background:transparent;
    border-radius:22px;
    padding:18px;
    box-shadow:var(--pen-shadow);
    overflow:hidden;
    position:relative;
  }
  .hero-inner{
    position:relative;
    display:flex; gap:16px;
    align-items:flex-start; justify-content:space-between;
    flex-wrap:wrap;
  }
  .hero h1{margin:0; font-size:24px; letter-spacing:-.2px; line-height:1.25; color:var(--ink)}
  .hero p{margin:8px 0 0; font-size:14px; color:var(--ink-muted); line-height:1.55; max-width:640px}
  .hero-actions{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px}

  .hero-actions{margin-top:12px}
  .hero-side{min-width:260px}

  /* Hero 769px 이상: 두 컬럼 비율 정리 */
  @media (min-width: 769px){
    .hero-inner{flex-wrap:nowrap; align-items:stretch; gap:20px}
    .hero-inner > div:first-child{flex:1 1 0; min-width:0; max-width:100%}
    .hero-side{flex:0 0 280px; min-width:260px; max-width:320px}
  }

  /* Hero 반응형 */
  @media (max-width: 768px){
    .hero{padding:14px 16px; margin-top:12px; border-radius:18px}
    .hero-inner{gap:14px}
    .hero-inner > div:first-child{min-width:0; flex:1 1 100%}
    .hero-side{min-width:0; width:100%}
    .hero h1{font-size:22px}
    .hero p{font-size:13px; max-width:100%}
  }
  @media (max-width: 480px){
    .hero{padding:12px 14px; margin-top:10px; border-radius:16px}
    .hero-inner{gap:12px}
    .hero h1{font-size:20px}
    .hero p{font-size:13px}
    .hero-actions{flex-direction:column; gap:8px; margin-top:10px}
    .hero-actions .btn{width:100%; justify-content:center}
  }
  
  /* Buttons - 볼펜 테두리 */
  .btn{
    border:var(--pen-stroke);
    background:#fff;
    color:var(--ink);
    padding:10px 12px;
    border-radius:12px;
    font-weight:1000;
    font-size:14px;
    cursor:default;
    display:inline-flex; align-items:center; gap:8px;
    white-space:nowrap;
    box-shadow:var(--pen-shadow);
  }
  .btn.primary{border:var(--pen-stroke); background:#e8eef7; color:var(--ink)}
  .btn.success{border:var(--pen-stroke); background:#e8f5e0; color:#2d5a1c}
  .btn.ghost{background:transparent; box-shadow:none; color:var(--ink)}
  .btn:disabled{ opacity:.65; cursor:not-allowed; }
  
  /* Grid + Cards */
  .grid{
    display:grid;
    grid-template-columns: 1fr 380px;
    gap:14px;
    margin-top:14px;
  }
  @media (max-width: 980px){ .grid{grid-template-columns:1fr} }
  
  .card{
    background:var(--card);
    border:var(--pen-stroke);
    border-radius:var(--radius);
    box-shadow:var(--pen-shadow);
    overflow:hidden;
  }
  .card-head{
    padding:14px;
    border-bottom:var(--pen-stroke);
    display:flex; align-items:flex-start; justify-content:space-between; gap:10px;
  }
  .card-head h2{margin:0; font-size:16px; letter-spacing:-.15px; color:var(--ink)}
  .sub{margin-top:4px; font-size:13px; color:var(--ink-muted)}
  .card-body{padding:14px}
  
  /* Progress - 단색 + 볼펜 테두리 */
  .progress-wrap{
    display:flex; flex-direction:column; gap:10px;
    border:var(--pen-stroke);
    border-radius:14px;
    background:var(--secondary);
    padding:12px;
    box-shadow:var(--pen-shadow);
  }
  .progress-top{display:flex; justify-content:space-between; align-items:flex-end; gap:10px}
  .big{font-size:24px; font-weight:1100; letter-spacing:-.3px; color:var(--ink); line-height:1}
  .small{font-size:12px; color:var(--ink-muted); font-weight:950}
  .bar{
    height:12px;
    background:#eef2f7;
    border-radius:999px;
    overflow:hidden;
    border:var(--pen-stroke);
  }
  .bar > div{
    height:100%;
    background:var(--ink);
    border-radius:999px;
    transition:width .25s ease;
  }
  .pill-row{display:flex; gap:10px; flex-wrap:wrap}
  .pill{
    display:inline-flex; align-items:center; gap:8px;
    padding:8px 10px;
    border:var(--pen-stroke);
    border-radius:999px;
    background:#fff;
    font-size:12px;
    font-weight:1000;
    color:var(--ink);
    box-shadow:var(--pen-shadow);
  }
  .pill.ok{background:#e8f5e0; color:#2d5a1c}
  .pill.info{background:#e8eef7; color:var(--ink)}
  
  /* Rows */
  .row{
    display:flex; align-items:center; justify-content:space-between; gap:10px;
    padding:12px;
    border:var(--pen-stroke);
    border-radius:14px;
    background:#fff;
    box-shadow:var(--pen-shadow);
  }
  .row .left{min-width:0}
  .row .title{font-weight:1100; font-size:14px; letter-spacing:-.1px; color:var(--ink)}
  .row .desc{
    margin-top:4px;
    font-size:12px;
    color:var(--ink-muted);
    font-weight:950;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  }
  .mini{
    width:92px; height:10px; border-radius:999px;
    background:#eef2f7; border:var(--pen-stroke);
    overflow:hidden;
  }
  .mini > div{
    height:100%;
    background:var(--ink);
    border-radius:999px;
    transition:width .25s ease;
  }
  .list{display:flex; flex-direction:column; gap:10px}
  
  /* Stats grid - 오늘 체크 + 전체 진행률 */
  .stats-grid{
    display:flex;
    flex-direction:column;
    gap:14px;
  }
  @media (min-width: 769px){
    .stats-grid{
      flex-direction:row;
      align-items:stretch;
    }
    .stats-grid .today-box{
      flex:0 0 280px;
      min-width:0;
    }
    .stats-grid .progress-wrap{
      flex:1 1 0;
      min-width:0;
    }
  }

  /* Today box - 단색 + 볼펜 테두리 */
  .today-box{
    border:var(--pen-stroke);
    background:rgba(126,211,33,.12);
    border-radius:14px;
    padding:12px;
    display:flex; align-items:flex-start; justify-content:space-between; gap:12px;
    box-shadow:var(--pen-shadow);
  }
  .today-box strong{font-size:14px; color:var(--ink)}
  .today-box p{margin:6px 0 0; font-size:12px; color:var(--ink-muted); font-weight:950; line-height:1.45}
  .today-box.today-checked{ background:rgba(126,211,33,.22); border-color:var(--ink); }

  /* Tags (small) */
  .tag{
    display:inline-flex; align-items:center; gap:6px;
    padding:6px 10px; border-radius:999px;
    border:var(--pen-stroke);
    font-size:12px; font-weight:1000;
    background:#fff; color:var(--ink);
    box-shadow:var(--pen-shadow);
  }
  .tag.ok{background:#e8f5e0; color:#2d5a1c}
  