
/* Container */
.vpn-container{max-width:1100px;margin:2rem auto;padding:0 16px}
.vpn-week-form{display:flex;gap:12px;align-items:center;margin:12px 0 24px 0;flex-wrap:wrap}
.vpn-week-form input[type=week]{padding:6px 8px}

/* User sections */
.vpn-user-section{margin:24px 0}
.vpn-user-section h2{margin:0 0 12px 0}

/* Columns */
.vpn-columns{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap}
.vpn-col{flex:1 1 400px;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:12px}
.vpn-col h3{margin-top:0}

/* Cards */
.vpn-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.vpn-card{border:1px solid #e5e7eb;border-radius:14px;padding:12px;box-shadow:0 1px 2px rgba(0,0,0,.04);display:flex;flex-direction:column;gap:8px}
.vpn-card-head{display:flex;justify-content:space-between;align-items:center}
.vpn-card h4{margin:0;font-size:16px;line-height:1.2}
.vpn-card-body{font-size:14px;color:#475569}
.vpn-card-foot{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#334155}
.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;border:1px solid #e2e8f0}
.badge-done{background:#ecfdf5}
.badge-undone{background:#fff7ed}
.muted{color:#94a3b8}

/* Forms */
.vpn-add{margin-top:28px}
.vpn-add-form input[type=text], .vpn-add-form textarea, .vpn-add-form select{width:100%;max-width:520px}
.vpn-add-form .hint{display:block;margin-top:4px;color:#64748b;font-size:12px}
