.portal-page{min-height:calc(100vh - var(--header-height));padding:var(--space-8) var(--container-padding);background:var(--color-background)}.portal-container{max-width:960px;margin:0 auto}.portal-header{margin-bottom:var(--space-8)}.portal-title{font-size:var(--text-h2);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-2)}.portal-subtitle{font-size:var(--text-body-lg);color:var(--color-text-muted);margin:0}.login-wrapper{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--header-height) - var(--space-16));padding:var(--space-8) var(--container-padding)}.login-card{width:100%;max-width:420px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-10)}.login-logo{text-align:center;margin-bottom:var(--space-8)}.login-logo svg{width:160px;height:auto;color:var(--color-text)}.login-heading{font-size:var(--text-h3);font-weight:var(--font-bold);color:var(--color-text);text-align:center;margin:0 0 var(--space-2)}.login-desc{font-size:var(--text-small);color:var(--color-text-muted);text-align:center;margin:0 0 var(--space-8)}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.form-field label{font-size:var(--text-small);font-weight:var(--font-semibold);color:var(--color-text)}.form-field input{padding:.75rem 1rem;font-size:var(--text-body);font-family:var(--font-primary);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #ef44441a}.login-error{padding:var(--space-3) var(--space-4);background:var(--color-primary-light);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--text-small)}.login-submit{padding:var(--btn-padding-y) var(--btn-padding-x);font-size:var(--btn-font-size);font-weight:var(--btn-font-weight);font-family:var(--font-primary);color:#fff;background:var(--color-primary-bg);border:none;border-radius:var(--btn-radius);cursor:pointer;transition:background var(--transition-fast)}.login-submit:hover{background:var(--color-primary-bg-hover)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6);margin-top:var(--space-6)}.dash-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.dash-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.dash-card-link{display:block;color:inherit;text-decoration:none}.dash-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);border-radius:var(--radius-md);margin-bottom:var(--space-4);color:var(--color-primary)}.dash-card-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 var(--space-2)}.dash-card-desc{font-size:var(--text-small);color:var(--color-text-muted);margin:0;line-height:var(--leading-relaxed)}.portal-layout{display:grid;grid-template-columns:240px 1fr;gap:var(--space-8);max-width:1200px;margin:0 auto;padding:calc(var(--header-height) + var(--space-8)) var(--container-padding) var(--space-8);min-height:100vh}.portal-sidebar{position:sticky;top:calc(var(--header-height) + var(--space-4));align-self:start}.portal-sidebar-header{margin-bottom:var(--space-6)}.portal-mobile-toggle{display:none}.portal-nav{display:flex;flex-direction:column;gap:var(--space-1)}.portal-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--text-small);font-weight:var(--font-medium);color:var(--color-text-muted);border-radius:var(--radius-md);transition:all var(--transition-fast)}.portal-nav-link:hover{color:var(--color-text);background:var(--color-surface-alt)}.portal-nav-link.active{color:var(--color-primary);background:var(--color-primary-light);font-weight:var(--font-semibold)}.portal-nav-link svg{width:20px;height:20px;flex-shrink:0}.portal-nav-divider{height:1px;background:var(--color-border);margin:var(--space-3) 0}.portal-nav-logout{color:var(--color-text-subtle)}.portal-nav-logout:hover{color:var(--color-primary);background:var(--color-primary-light)}.portal-content{min-width:0}.plan-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-caption);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wider);border-radius:var(--radius-full)}.plan-badge--start{background:var(--color-surface-alt);color:var(--color-text-muted)}.plan-badge--progress{background:#eff6ff;color:#2563eb}.plan-badge--unlimited{background:#fef3c7;color:#d97706}.profile-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.profile-section-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.profile-row{display:grid;grid-template-columns:160px 1fr;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--color-surface-alt)}.profile-row:last-child{border-bottom:none}.profile-label{font-size:var(--text-small);font-weight:var(--font-medium);color:var(--color-text-muted)}.profile-value{font-size:var(--text-body);color:var(--color-text)}.locked-overlay{position:relative;opacity:.5;pointer-events:none}.lock-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-caption);color:var(--color-text-muted)}@media(max-width:768px){.portal-layout{grid-template-columns:1fr;gap:var(--space-4)}.portal-sidebar{position:static;min-width:0}.portal-sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0;padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.portal-mobile-toggle{display:flex;align-items:center;justify-content:center;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast)}.portal-mobile-toggle:hover{background:var(--color-border)}.portal-nav{display:none;flex-direction:column;padding:var(--space-2);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-top:var(--space-2);box-shadow:var(--shadow-sm)}.portal-sidebar.is-open .portal-nav{display:flex}.portal-nav-link{white-space:normal;padding:var(--space-3) var(--space-4);font-size:var(--text-small)}.portal-nav-divider{display:block;margin:var(--space-2) 0}.login-card{padding:var(--space-6)}.dashboard-grid{grid-template-columns:1fr}.profile-row{grid-template-columns:1fr;gap:var(--space-1)}}.q-meta{display:flex;gap:var(--space-6);padding:var(--space-4) var(--space-5);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-6);font-size:var(--text-small);color:var(--color-text-muted)}.q-meta-item strong{display:block;font-size:var(--text-caption);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--space-1)}.q-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-5)}.q-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.q-section-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.q-edit-btn{padding:var(--space-2) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-primary);cursor:pointer;font-size:var(--text-small);font-family:var(--font-primary);font-weight:var(--font-medium);transition:all var(--transition-fast)}.q-edit-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.q-row{display:grid;grid-template-columns:200px 1fr;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--color-surface-alt);align-items:start}.q-row:last-child{border-bottom:none}.q-label{font-size:var(--text-small);color:var(--color-text-muted);font-weight:var(--font-medium);padding-top:2px}.q-value{font-size:var(--text-body);color:var(--color-text);word-break:break-word}.q-value--empty{color:var(--color-text-muted);font-style:italic;font-size:var(--text-small)}.q-input,.q-section--editing .q-value{display:none}.q-section--editing .q-input{display:block}.q-section--editing .q-edit-btn{display:none}.q-section--editing .q-input input,.q-section--editing .q-input select,.q-section--editing .q-input textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-body);font-family:var(--font-primary);color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition-fast);box-sizing:border-box}.q-section--editing .q-input input:focus,.q-section--editing .q-input select:focus,.q-section--editing .q-input textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #dc26261a}.q-section--editing .q-input textarea{min-height:80px;resize:vertical}.q-checkbox-group{display:flex;flex-wrap:wrap;gap:var(--space-3)}.q-checkbox-group label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-small);cursor:pointer}.q-sport-subsection{display:none}.q-sport-subsection.visible{display:block}.q-sport-subsection-label{font-size:var(--text-caption);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--color-text-muted);font-weight:var(--font-semibold);margin:var(--space-4) 0 var(--space-3);padding-left:var(--space-4);border-left:2px solid var(--color-border);padding-top:var(--space-1);padding-bottom:var(--space-1)}.q-actions{display:none;gap:var(--space-3);margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.q-section--editing .q-actions{display:flex}.q-save-btn{padding:var(--space-2) var(--space-6);background:var(--color-primary-bg);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-small);font-family:var(--font-primary);font-weight:var(--font-semibold);transition:background var(--transition-fast)}.q-save-btn:hover{background:var(--color-primary-bg-hover)}.q-save-btn:disabled{opacity:.6;cursor:not-allowed}.q-cancel-btn{padding:var(--space-2) var(--space-5);background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-small);font-family:var(--font-primary);transition:all var(--transition-fast)}.q-cancel-btn:hover{color:var(--color-text);border-color:var(--color-text-muted)}.q-status-msg{padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-small);margin-bottom:var(--space-5)}.q-status-msg--success{background:#ecfdf5;color:#065f46;border:1px solid rgba(6,95,70,.2)}.q-status-msg--error{background:#fef2f2;color:#991b1b;border:1px solid rgba(153,27,27,.2)}.q-empty-state{text-align:center;padding:var(--space-16) var(--space-8)}.q-empty-icon{opacity:.2;margin-bottom:var(--space-6)}.q-empty-state h3{font-size:var(--text-h3);color:var(--color-text);margin:0 0 var(--space-3)}.q-empty-state p{color:var(--color-text-muted);margin:0 0 var(--space-8);font-size:var(--text-body)}.q-empty-state a{display:inline-block;padding:var(--space-3) var(--space-6);background:var(--color-primary-bg);color:#fff;border-radius:var(--radius-md);text-decoration:none;font-weight:var(--font-semibold);font-size:var(--text-small);transition:background var(--transition-fast)}.q-empty-state a:hover{background:var(--color-primary-bg-hover)}@media(max-width:768px){.q-row{grid-template-columns:1fr;gap:var(--space-1)}.q-meta{flex-direction:column;gap:var(--space-3)}.q-actions{flex-direction:column}.q-save-btn,.q-cancel-btn{width:100%;text-align:center}}
