Spaces:
Running
Running
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| BREATHE β Design System | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| LANDING PAGE | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| /* Root wrapper */ | |
| .lp { | |
| background: var(--bg); | |
| color: var(--text); | |
| font-family: 'Inter', sans-serif; | |
| overflow-x: hidden; | |
| } | |
| /* ββ Shared gradient text ββ */ | |
| .lp-gradient-text { | |
| background: linear-gradient(135deg, var(--accent) 0%, var(--accent2) 60%, #f472b6 100%); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| background-clip: text; | |
| } | |
| /* ββ Nav βββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .lp-nav { | |
| position: fixed; top: 0; left: 0; right: 0; z-index: 90; | |
| background: rgba(var(--nav-bg-rgb, 7,9,15),.85); | |
| backdrop-filter: blur(20px); | |
| border-bottom: 1px solid var(--border); | |
| } | |
| .lp-nav-inner { | |
| max-width: 1100px; margin: 0 auto; | |
| display: flex; align-items: center; | |
| padding: 0 24px; height: 64px; gap: 32px; | |
| } | |
| .lp-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; flex-shrink: 0; } | |
| .lp-logo-img { height: 48px; width: auto; display: block; } | |
| .lp-nav-links { display: flex; gap: 4px; flex: 1; } | |
| .lp-nav-link { padding: 7px 14px; border-radius: var(--r-sm); color: var(--muted); | |
| font-size: .88rem; font-weight: 500; transition: var(--t); text-decoration: none; } | |
| .lp-nav-link:hover { color: var(--text); background: var(--surface2); } | |
| .lp-nav-cta { display: flex; align-items: center; gap: 10px; flex-shrink: 0; } | |
| /* Nav buttons */ | |
| .lp-btn-ghost { | |
| padding: 8px 18px; border: 1px solid var(--border2); border-radius: var(--r-sm); | |
| color: var(--muted2); font-size: .88rem; font-weight: 500; | |
| background: transparent; text-decoration: none; transition: var(--t); | |
| } | |
| .lp-btn-ghost:hover { color: var(--text); border-color: var(--accent); } | |
| .lp-btn-solid { | |
| padding: 8px 18px; border-radius: var(--r-sm); border: none; | |
| background: linear-gradient(135deg, var(--accent), var(--accent2)); | |
| color: #fff; font-size: .88rem; font-weight: 600; text-decoration: none; | |
| transition: opacity var(--t), box-shadow var(--t); | |
| box-shadow: 0 4px 14px rgba(91,156,246,.3); | |
| } | |
| .lp-btn-solid:hover { opacity: .88; box-shadow: 0 6px 20px rgba(91,156,246,.45); } | |
| /* ββ Hero βββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .lp-hero { | |
| min-height: 100vh; | |
| display: flex; align-items: center; justify-content: center; | |
| text-align: center; | |
| position: relative; overflow: hidden; | |
| padding: 120px 24px 80px; | |
| } | |
| /* Rings */ | |
| .lp-rings { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; pointer-events: none; } | |
| .lp-ring { position: absolute; border-radius: 50%; animation: lp-breathe 6s ease-in-out infinite; } | |
| .lp-ring-1 { width: 160px; height: 160px; border: 1.5px solid rgba(91,156,246,.5); animation-delay: 0s; } | |
| .lp-ring-2 { width: 300px; height: 300px; border: 1px solid rgba(91,156,246,.28); animation-delay: .8s; } | |
| .lp-ring-3 { width: 460px; height: 460px; border: 1px solid rgba(167,139,250,.18);animation-delay: 1.6s; } | |
| .lp-ring-4 { width: 640px; height: 640px; border: 1px solid rgba(167,139,250,.1); animation-delay: 2.4s; } | |
| .lp-ring-5 { width: 860px; height: 860px; border: 1px solid rgba(91,156,246,.06); animation-delay: 3.2s; } | |
| @keyframes lp-breathe { | |
| 0%,100% { transform: scale(.94); opacity: .6; } | |
| 50% { transform: scale(1.06); opacity: .2; } | |
| } | |
| /* Radial glow behind hero */ | |
| .lp-hero::before { | |
| content: ''; | |
| position: absolute; inset: 0; | |
| background: radial-gradient(ellipse 60% 50% at 50% 40%, rgba(91,156,246,.1) 0%, transparent 70%); | |
| pointer-events: none; | |
| } | |
| .lp-hero-content { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; } | |
| .lp-hero-badge { | |
| display: inline-block; margin-bottom: 24px; | |
| padding: 6px 16px; border-radius: 20px; | |
| background: rgba(91,156,246,.1); border: 1px solid rgba(91,156,246,.25); | |
| color: var(--accent); font-size: .78rem; font-weight: 600; letter-spacing: .04em; | |
| } | |
| .lp-hero-h1 { | |
| font-size: clamp(2.4rem, 6vw, 4.2rem); | |
| font-weight: 900; line-height: 1.1; letter-spacing: -.02em; | |
| color: var(--text); margin-bottom: 22px; | |
| } | |
| .lp-hero-sub { | |
| font-size: clamp(.95rem, 2vw, 1.15rem); | |
| color: var(--muted2); line-height: 1.75; | |
| max-width: 580px; margin: 0 auto 36px; | |
| } | |
| .lp-hero-btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; } | |
| /* Hero CTA buttons */ | |
| .lp-btn-hero-primary { | |
| display: inline-flex; align-items: center; gap: 8px; | |
| padding: 14px 32px; border-radius: var(--r-sm); border: none; | |
| background: linear-gradient(135deg, var(--accent), var(--accent2)); | |
| color: #fff; font-size: 1rem; font-weight: 700; text-decoration: none; | |
| box-shadow: 0 6px 28px rgba(91,156,246,.4); | |
| transition: opacity var(--t), transform var(--t), box-shadow var(--t); | |
| } | |
| .lp-btn-hero-primary:hover { opacity: .88; transform: translateY(-2px); box-shadow: 0 10px 36px rgba(91,156,246,.55); } | |
| .lp-btn--xl { padding: 16px 40px; font-size: 1.05rem; } | |
| .lp-btn-hero-ghost { | |
| display: inline-flex; align-items: center; gap: 8px; | |
| padding: 14px 32px; border-radius: var(--r-sm); | |
| border: 1px solid var(--border2); color: var(--muted2); | |
| font-size: 1rem; font-weight: 500; text-decoration: none; | |
| transition: var(--t); background: transparent; | |
| } | |
| .lp-btn-hero-ghost:hover { color: var(--text); border-color: var(--accent); background: rgba(91,156,246,.05); } | |
| .lp-btn-arrow { transition: transform var(--t); } | |
| .lp-btn-hero-primary:hover .lp-btn-arrow { transform: translateX(4px); } | |
| /* ββ Stats bar βββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .lp-stats { | |
| display: flex; align-items: center; justify-content: center; | |
| gap: 0; flex-wrap: wrap; | |
| background: var(--surface); | |
| border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); | |
| padding: 28px 24px; | |
| } | |
| .lp-stat { text-align: center; padding: 8px 40px; } | |
| .lp-stat-num { font-size: 1.7rem; font-weight: 800; color: var(--accent); margin-bottom: 4px; } | |
| .lp-stat-lbl { font-size: .78rem; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; } | |
| .lp-stat-div { width: 1px; height: 44px; background: var(--border); flex-shrink: 0; } | |
| /* ββ Sections ββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .lp-section { | |
| max-width: 1100px; margin: 0 auto; | |
| padding: 96px 24px; | |
| text-align: center; | |
| } | |
| .lp-section--alt { | |
| background: var(--surface); | |
| max-width: 100%; padding: 96px 24px; | |
| } | |
| .lp-section--alt > * { max-width: 1100px; margin-left: auto; margin-right: auto; } | |
| .lp-section-label { | |
| font-size: .73rem; font-weight: 700; letter-spacing: .12em; | |
| text-transform: uppercase; color: var(--accent); | |
| margin-bottom: 14px; | |
| } | |
| .lp-section-h2 { | |
| font-size: clamp(1.7rem, 4vw, 2.8rem); font-weight: 800; | |
| line-height: 1.2; letter-spacing: -.02em; color: var(--text); | |
| margin-bottom: 14px; | |
| } | |
| .lp-section-sub { | |
| color: var(--muted2); font-size: 1rem; max-width: 520px; | |
| margin: 0 auto 56px; line-height: 1.7; | |
| } | |
| /* ββ Feature cards βββββββββββββββββββββββββββββββββββββββββββ */ | |
| .lp-features { | |
| display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; | |
| margin-top: 56px; | |
| } | |
| .lp-feat-card { | |
| background: var(--surface); border: 1px solid var(--border); | |
| border-radius: var(--r); padding: 28px 24px; text-align: left; | |
| transition: border-color var(--t), transform var(--t), box-shadow var(--t); | |
| } | |
| .lp-feat-card:hover { | |
| border-color: var(--fc, var(--accent)); | |
| transform: translateY(-4px); | |
| box-shadow: 0 12px 40px rgba(0,0,0,.4); | |
| } | |
| .lp-feat-icon { width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 1.4rem; margin-bottom: 18px; } | |
| .lp-feat-title { font-size: 1rem; font-weight: 700; color: var(--text); margin-bottom: 10px; } | |
| .lp-feat-desc { font-size: .875rem; color: var(--muted); line-height: 1.7; } | |
| /* ββ How it works ββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .lp-steps { | |
| display: flex; align-items: flex-start; justify-content: center; | |
| gap: 0; margin-top: 56px; position: relative; | |
| max-width: 800px; margin-left: auto; margin-right: auto; | |
| } | |
| .lp-step { | |
| flex: 1; display: flex; flex-direction: column; align-items: center; | |
| text-align: center; position: relative; padding: 0 16px; | |
| } | |
| .lp-step-n { | |
| width: 56px; height: 56px; border-radius: 50%; flex-shrink: 0; | |
| background: linear-gradient(135deg, var(--accent), var(--accent2)); | |
| color: #fff; font-size: 1rem; font-weight: 800; | |
| display: flex; align-items: center; justify-content: center; | |
| box-shadow: 0 0 0 6px rgba(91,156,246,.15), 0 4px 18px rgba(91,156,246,.3); | |
| margin-bottom: 20px; z-index: 1; | |
| } | |
| .lp-step-line { | |
| position: absolute; top: 28px; left: calc(50% + 36px); right: calc(-50% + 36px); | |
| height: 1px; background: linear-gradient(90deg, var(--accent), var(--accent2)); | |
| opacity: .35; | |
| } | |
| .lp-step-title { font-size: 1rem; font-weight: 700; margin-bottom: 8px; color: var(--text); } | |
| .lp-step-desc { font-size: .875rem; color: var(--muted); line-height: 1.65; } | |
| /* ββ Stress levels βββββββββββββββββββββββββββββββββββββββββββ */ | |
| .lp-levels { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; margin-top: 56px; } | |
| .lp-level-card { | |
| background: var(--lb, rgba(91,156,246,.08)); | |
| border: 1px solid rgba(255,255,255,.06); | |
| border-top: 3px solid var(--lc, var(--accent)); | |
| border-radius: var(--r); padding: 22px 18px; text-align: left; | |
| transition: transform var(--t), box-shadow var(--t); | |
| } | |
| .lp-level-card:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(0,0,0,.3); } | |
| .lp-level-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; } | |
| .lp-level-badge { padding: 4px 12px; border-radius: 20px; font-size: .8rem; font-weight: 700; } | |
| .lp-level-range { font-size: .75rem; color: var(--muted); } | |
| .lp-level-desc { font-size: .82rem; color: var(--muted2); line-height: 1.55; margin-bottom: 16px; } | |
| .lp-level-bar-track { height: 4px; background: rgba(255,255,255,.08); border-radius: 2px; overflow: hidden; } | |
| .lp-level-bar-fill { height: 100%; width: 100%; border-radius: 2px; } | |
| /* ββ CTA section βββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .lp-cta { | |
| position: relative; text-align: center; | |
| padding: 120px 24px; | |
| background: var(--surface); | |
| border-top: 1px solid var(--border); | |
| overflow: hidden; | |
| } | |
| .lp-cta-glow { | |
| position: absolute; top: 50%; left: 50%; | |
| transform: translate(-50%, -50%); | |
| width: 600px; height: 300px; | |
| background: radial-gradient(ellipse, rgba(91,156,246,.15) 0%, transparent 70%); | |
| pointer-events: none; | |
| } | |
| .lp-cta-h2 { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 800; letter-spacing: -.02em; margin-bottom: 14px; position: relative; } | |
| .lp-cta-sub { color: var(--muted2); font-size: 1rem; margin-bottom: 36px; position: relative; } | |
| /* ββ Footer ββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .lp-footer { | |
| display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; | |
| gap: 14px; padding: 28px 40px; | |
| border-top: 1px solid var(--border); | |
| background: var(--bg); | |
| } | |
| .lp-footer-logo { display: flex; align-items: center; } | |
| .lp-footer-logo-img { height: 32px; width: auto; } | |
| .lp-footer-copy { font-size: .8rem; color: var(--muted); } | |
| .lp-footer-links { display: flex; gap: 20px; } | |
| .lp-footer-link { font-size: .82rem; color: var(--muted); transition: color var(--t); text-decoration: none; } | |
| .lp-footer-link:hover { color: var(--text); } | |
| /* ββ Landing page responsive βββββββββββββββββββββββββββββββββ */ | |
| @media (max-width: 1024px) { | |
| .lp-features { grid-template-columns: repeat(2, 1fr); } | |
| .lp-levels { grid-template-columns: repeat(3, 1fr); } | |
| } | |
| @media (max-width: 768px) { | |
| .lp-nav-links { display: none; } | |
| .lp-hero { padding: 100px 20px 60px; } | |
| .lp-stats { gap: 0; } | |
| .lp-stat { padding: 8px 20px; } | |
| .lp-stat-div { display: none; } | |
| .lp-steps { flex-direction: column; align-items: center; gap: 32px; } | |
| .lp-step-line { display: none; } | |
| .lp-levels { grid-template-columns: repeat(2, 1fr); } | |
| .lp-footer { flex-direction: column; align-items: center; text-align: center; padding: 24px 20px; } | |
| } | |
| @media (max-width: 540px) { | |
| .lp-features { grid-template-columns: 1fr; } | |
| .lp-levels { grid-template-columns: 1fr; } | |
| .lp-nav-cta .lp-btn-ghost { display: none; } | |
| .lp-section { padding: 64px 20px; } | |
| .lp-cta { padding: 80px 20px; } | |
| } | |
| :root, | |
| [data-theme="dark"] { | |
| --bg: #07090f; | |
| --surface: #0d1420; | |
| --surface2: #121c2e; | |
| --surface3: #192436; | |
| --border: #1a2840; | |
| --border2: #243554; | |
| --accent: #5b9cf6; | |
| --accent2: #a78bfa; | |
| --glow: rgba(91,156,246,.2); | |
| --text: #e2e8f0; | |
| --muted: #64748b; | |
| --muted2: #94a3b8; | |
| --success: #2dd4a5; | |
| --warning: #fbbf24; | |
| --danger: #f87171; | |
| --minimal: #2dd4a5; | |
| --mild: #86efac; | |
| --moderate: #fbbf24; | |
| --severe: #fb923c; | |
| --critical: #f87171; | |
| --r: 16px; | |
| --r-sm: 10px; | |
| --r-xs: 6px; | |
| --sh: 0 8px 40px rgba(0,0,0,.55); | |
| --sh-sm:0 4px 20px rgba(0,0,0,.35); | |
| --t: 200ms cubic-bezier(.4,0,.2,1); | |
| --nav-bg-rgb: 7,9,15; | |
| } | |
| [data-theme="light"] { | |
| /* Palette: FFDDDA Β· FFF4CB Β· CBEDD4 Β· E3D7FF Β· D0EAFF Β· FFF9F2 */ | |
| --bg: #FFF9F2; /* warm cream β page background */ | |
| --surface: #FFFFFF; /* pure white β cards / modals */ | |
| --surface2: #FFDDDA; /* rose petal β hover / secondary surface */ | |
| --surface3: #FFF4CB; /* soft yellow β tertiary / highlight */ | |
| --border: #F0C8C4; /* rose border (FFDDDA darkened) */ | |
| --border2: #C4E8D0; /* mint border (CBEDD4 darkened) */ | |
| --accent: #6A9FD8; /* D0EAFF deepened β interactive blue */ | |
| --accent2: #9B8BD4; /* E3D7FF deepened β interactive lavender */ | |
| --glow: rgba(208,234,255,.45); | |
| --text: #1a1228; /* near-black with warm-purple tint */ | |
| --muted: #7a6e80; | |
| --muted2: #5c5266; | |
| --success: #2ea868; /* CBEDD4 deepened */ | |
| --warning: #c98a0a; /* FFF4CB deepened */ | |
| --danger: #d94f4f; /* FFDDDA deepened */ | |
| --minimal: #2ea868; | |
| --mild: #52c48a; | |
| --moderate: #c98a0a; | |
| --severe: #e07030; | |
| --critical: #d94f4f; | |
| --sh: 0 8px 40px rgba(255,221,218,.55); | |
| --sh-sm: 0 4px 20px rgba(227,215,255,.35); | |
| --nav-bg-rgb: 255,249,242; | |
| } | |
| *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } | |
| html { scroll-behavior: smooth; } | |
| body { font-family: 'Inter', sans-serif; background: var(--bg); color: var(--text); | |
| font-size: 15px; line-height: 1.6; min-height: 100vh; } | |
| a { text-decoration: none; } | |
| button { font-family: inherit; cursor: pointer; } | |
| /* ββ Scrollbar βββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| ::-webkit-scrollbar { width: 6px; } | |
| ::-webkit-scrollbar-track { background: var(--bg); } | |
| ::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 3px; } | |
| /* ββ Loaders βββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .full-loader { display: flex; align-items: center; justify-content: center; min-height: 100vh; } | |
| .page-loader { display: flex; align-items: center; justify-content: center; min-height: 40vh; } | |
| .spinner { width: 32px; height: 32px; border: 3px solid var(--border2); | |
| border-top-color: var(--accent); border-radius: 50%; | |
| animation: spin .7s linear infinite; } | |
| @keyframes spin { to { transform: rotate(360deg); } } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| AUTH SCREEN | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .auth-screen { | |
| min-height: 100vh; | |
| display: flex; align-items: center; justify-content: center; | |
| background: var(--bg); | |
| position: relative; overflow: hidden; | |
| } | |
| /* Breathing rings animation */ | |
| .breath-rings { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; pointer-events: none; } | |
| .ring { position: absolute; border-radius: 50%; border: 1px solid rgba(91,156,246,.18); animation: breathe 5s ease-in-out infinite; } | |
| .ring-1 { width: 180px; height: 180px; animation-delay: 0s; border-color: rgba(91,156,246,.35); } | |
| .ring-2 { width: 320px; height: 320px; animation-delay: .7s; border-color: rgba(91,156,246,.2); } | |
| .ring-3 { width: 480px; height: 480px; animation-delay: 1.4s; border-color: rgba(167,139,250,.12); } | |
| .ring-4 { width: 660px; height: 660px; animation-delay: 2.1s; border-color: rgba(167,139,250,.07); } | |
| @keyframes breathe { | |
| 0%,100% { transform: scale(.95); opacity: .5; } | |
| 50% { transform: scale(1.05); opacity: .2; } | |
| } | |
| .auth-card { | |
| position: relative; z-index: 1; | |
| background: rgba(13,20,32,.9); | |
| backdrop-filter: blur(24px); | |
| border: 1px solid var(--border2); | |
| border-radius: var(--r); | |
| padding: 44px 40px; | |
| width: 100%; max-width: 420px; | |
| box-shadow: var(--sh), 0 0 80px rgba(91,156,246,.1); | |
| } | |
| .auth-brand { text-align: center; margin-bottom: 28px; } | |
| .auth-logo { height: 100px; width: auto; display: block; margin: 0 auto 8px; } | |
| .auth-title { font-size: 1.9rem; font-weight: 800; letter-spacing: .08em; | |
| background: linear-gradient(135deg, var(--accent), var(--accent2)); | |
| -webkit-background-clip: text; -webkit-text-fill-color: transparent; } | |
| .auth-subtitle { color: var(--muted); font-size: .85rem; margin-top: 4px; } | |
| .auth-tabs { display: flex; background: var(--bg); border-radius: var(--r-sm); padding: 4px; margin-bottom: 24px; } | |
| .auth-tab { flex: 1; padding: 9px; border: none; border-radius: 7px; background: transparent; | |
| color: var(--muted); font-size: .9rem; font-weight: 500; transition: var(--t); } | |
| .auth-tab--active { background: var(--surface2); color: var(--text); box-shadow: var(--sh-sm); } | |
| .auth-form { display: flex; flex-direction: column; gap: 14px; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| FORM ELEMENTS | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .field { display: flex; flex-direction: column; gap: 6px; } | |
| .field label { font-size: .78rem; font-weight: 600; color: var(--muted2); | |
| text-transform: uppercase; letter-spacing: .05em; } | |
| .field label small { text-transform: none; font-weight: 400; color: var(--muted); } | |
| input[type=text], input[type=email], input[type=password], input[type=number], | |
| select, textarea { | |
| width: 100%; padding: 11px 14px; | |
| background: var(--bg); border: 1px solid var(--border); | |
| border-radius: var(--r-sm); color: var(--text); | |
| font-size: .92rem; font-family: inherit; outline: none; | |
| transition: border-color var(--t), box-shadow var(--t); | |
| } | |
| input:focus, select:focus, textarea:focus { | |
| border-color: var(--accent); box-shadow: 0 0 0 3px rgba(91,156,246,.14); | |
| } | |
| input::placeholder { color: var(--muted); } | |
| select option { background: var(--surface2); } | |
| textarea { resize: vertical; } | |
| .form-error { | |
| background: rgba(248,113,113,.1); border: 1px solid rgba(248,113,113,.35); | |
| border-radius: var(--r-sm); color: var(--danger); | |
| padding: 10px 14px; font-size: .88rem; margin-bottom: 4px; | |
| } | |
| /* ββ Buttons βββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .btn-primary { | |
| display: inline-flex; align-items: center; justify-content: center; gap: 8px; | |
| padding: 11px 24px; border: none; border-radius: var(--r-sm); | |
| background: linear-gradient(135deg, var(--accent), var(--accent2)); | |
| color: #fff; font-size: .95rem; font-weight: 600; | |
| transition: opacity var(--t), transform var(--t), box-shadow var(--t); | |
| box-shadow: 0 4px 18px rgba(91,156,246,.35); | |
| letter-spacing: .01em; | |
| } | |
| .btn-primary:hover { opacity: .88; transform: translateY(-2px); box-shadow: 0 8px 28px rgba(91,156,246,.5); } | |
| .btn-primary:active { opacity: 1; transform: translateY(0); } | |
| .btn-primary:disabled { opacity: .45; cursor: not-allowed; transform: none; } | |
| .btn--full { width: 100%; } | |
| .btn--lg { padding: 13px 32px; font-size: 1rem; } | |
| .btn-secondary { | |
| display: inline-flex; align-items: center; justify-content: center; gap: 6px; | |
| padding: 10px 22px; border: 1px solid var(--accent); | |
| border-radius: var(--r-sm); color: var(--accent); | |
| font-size: .9rem; font-weight: 500; background: transparent; | |
| transition: var(--t); | |
| } | |
| .btn-secondary:hover { background: rgba(91,156,246,.1); border-color: var(--accent2); } | |
| .btn-ghost { | |
| display: inline-flex; align-items: center; justify-content: center; gap: 6px; | |
| padding: 9px 18px; border: 1px solid var(--border2); | |
| border-radius: var(--r-sm); color: var(--muted2); | |
| font-size: .88rem; font-weight: 500; background: transparent; | |
| transition: var(--t); | |
| } | |
| .btn-ghost:hover { color: var(--text); border-color: var(--accent); background: rgba(91,156,246,.05); } | |
| .btn-spinner { | |
| display: inline-block; width: 16px; height: 16px; | |
| border: 2px solid rgba(255,255,255,.3); border-top-color: #fff; | |
| border-radius: 50%; animation: spin .7s linear infinite; | |
| } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| APP SHELL | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .app-shell { display: flex; min-height: 100vh; } | |
| /* Mobile bar */ | |
| .mobile-bar { | |
| display: none; position: fixed; top: 0; left: 0; right: 0; z-index: 50; | |
| height: 56px; background: var(--surface); | |
| border-bottom: 1px solid var(--border); | |
| align-items: center; gap: 14px; padding: 0 16px; | |
| } | |
| .hamburger { background: none; border: none; color: var(--text); font-size: 1.3rem; } | |
| .mobile-brand { font-weight: 700; font-size: 1rem; color: var(--accent); letter-spacing: .05em; } | |
| /* Sidebar */ | |
| .sidebar { | |
| width: 248px; flex-shrink: 0; | |
| background: var(--surface); | |
| border-right: 1px solid var(--border); | |
| display: flex; flex-direction: column; | |
| position: sticky; top: 0; height: 100vh; | |
| } | |
| .sidebar-top { flex: 1; padding: 20px 12px 0; overflow-y: auto; } | |
| .sidebar-bottom { padding: 12px; border-top: 1px solid var(--border); } | |
| .sidebar-brand { | |
| display: flex; align-items: center; gap: 10px; | |
| margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border); | |
| } | |
| .brand-logo { height: 52px; width: auto; display: block; } | |
| .mobile-brand-logo { height: 32px; width: auto; display: block; } | |
| .mobile-theme-toggle { | |
| background: none; border: none; font-size: 1.2rem; | |
| cursor: pointer; padding: 4px 8px; border-radius: var(--r-xs); | |
| transition: var(--t); line-height: 1; | |
| } | |
| .mobile-theme-toggle:hover { background: var(--surface2); } | |
| .brand-name { font-size: .95rem; font-weight: 800; color: var(--accent); letter-spacing: .06em; } | |
| .brand-sub { font-size: .68rem; color: var(--muted); margin-top: 1px; } | |
| .sidebar-nav { display: flex; flex-direction: column; gap: 2px; } | |
| .nav-section-label { | |
| font-size: .67rem; font-weight: 700; letter-spacing: .1em; | |
| text-transform: uppercase; color: var(--muted); padding: 6px 12px 4px; | |
| margin-top: 4px; | |
| } | |
| .nav-link { | |
| display: flex; align-items: center; gap: 10px; | |
| padding: 9px 12px; border-radius: var(--r-sm); | |
| color: var(--muted); font-size: .88rem; font-weight: 500; | |
| transition: var(--t); position: relative; | |
| border-left: 2px solid transparent; | |
| } | |
| .nav-link:hover { background: var(--surface2); color: var(--text); border-left-color: var(--border2); } | |
| .nav-link--active { background: rgba(91,156,246,.1); color: var(--accent); border-left-color: var(--accent); font-weight: 600; } | |
| .nav-link--active .nav-icon { filter: drop-shadow(0 0 5px var(--accent)); } | |
| .nav-icon { font-size: 1rem; flex-shrink: 0; } | |
| .user-chip { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; } | |
| .user-avatar { | |
| width: 34px; height: 34px; border-radius: 50%; | |
| background: linear-gradient(135deg, var(--accent), var(--accent2)); | |
| display: flex; align-items: center; justify-content: center; | |
| font-size: .78rem; font-weight: 700; color: #fff; flex-shrink: 0; | |
| border: 2px solid rgba(91,156,246,.3); | |
| } | |
| .user-meta { min-width: 0; } | |
| .user-name { font-size: .86rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } | |
| .user-email { font-size: .72rem; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } | |
| .logout-btn { | |
| width: 100%; padding: 8px 12px; | |
| background: none; border: 1px solid var(--border); | |
| border-radius: var(--r-sm); color: var(--muted); | |
| font-size: .82rem; transition: var(--t); | |
| display: flex; align-items: center; justify-content: center; gap: 6px; | |
| } | |
| .logout-btn:hover { color: var(--danger); border-color: rgba(248,113,113,.4); background: rgba(248,113,113,.05); } | |
| /* Theme toggle */ | |
| .theme-toggle { | |
| width: 100%; padding: 8px 12px; margin-bottom: 6px; | |
| background: none; border: 1px solid var(--border); | |
| border-radius: var(--r-sm); color: var(--muted); | |
| font-size: .82rem; transition: var(--t); | |
| display: flex; align-items: center; justify-content: center; gap: 8px; | |
| } | |
| .theme-toggle:hover { color: var(--text); border-color: var(--accent); background: rgba(91,156,246,.06); } | |
| .theme-toggle-icon { font-size: 1rem; line-height: 1; } | |
| /* Main area */ | |
| .main-area { flex: 1; overflow-y: auto; min-width: 0; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| PAGE LAYOUT | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .page { max-width: 1080px; margin: 0 auto; padding: 36px 32px; animation: pageIn .25s ease; } | |
| .page-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 28px; gap: 16px; flex-wrap: wrap; } | |
| .page-title { font-size: 1.7rem; font-weight: 800; color: var(--text); letter-spacing: -.01em; } | |
| .page-sub { color: var(--muted); font-size: .88rem; margin-top: 4px; } | |
| @keyframes pageIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| CARDS | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .card { | |
| background: var(--surface); border: 1px solid var(--border); | |
| border-radius: var(--r); padding: 24px; margin-bottom: 20px; | |
| box-shadow: var(--sh-sm); | |
| transition: border-color var(--t), box-shadow var(--t); | |
| } | |
| .card:hover { border-color: var(--border2); } | |
| .card-title { | |
| font-size: .72rem; font-weight: 700; color: var(--muted); | |
| text-transform: uppercase; letter-spacing: .1em; margin-bottom: 16px; | |
| } | |
| .two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| STAT CARDS | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 20px; } | |
| .stat-card { | |
| background: var(--surface); border: 1px solid var(--border); | |
| border-radius: var(--r); padding: 20px 18px; | |
| transition: border-color var(--t), transform var(--t), box-shadow var(--t); | |
| position: relative; overflow: hidden; | |
| } | |
| .stat-card::before { | |
| content: ''; | |
| position: absolute; top: 0; left: 0; right: 0; height: 3px; | |
| background: linear-gradient(90deg, var(--accent), var(--accent2)); | |
| opacity: 0; transition: opacity var(--t); | |
| } | |
| .stat-card:hover { border-color: var(--border2); transform: translateY(-3px); box-shadow: 0 8px 30px rgba(0,0,0,.4); } | |
| .stat-card:hover::before { opacity: 1; } | |
| .stat-icon { font-size: 1.5rem; margin-bottom: 12px; } | |
| .stat-value { font-size: 1.7rem; font-weight: 800; color: var(--accent); line-height: 1; margin-bottom: 6px; letter-spacing: -.02em; } | |
| .stat-label { font-size: .72rem; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; } | |
| .trend--up { color: var(--danger) ; } | |
| .trend--down { color: var(--success) ; } | |
| .trend--flat { color: var(--muted) ; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| DASHBOARD β RECENT LIST | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .recent-list { display: flex; flex-direction: column; gap: 6px; } | |
| .recent-item { | |
| display: flex; align-items: center; justify-content: space-between; | |
| padding: 11px 14px; background: var(--surface2); border-radius: var(--r-sm); | |
| cursor: pointer; border: 1px solid transparent; transition: var(--t); | |
| } | |
| .recent-item:hover { border-color: var(--border2); background: var(--surface3); transform: translateX(3px); } | |
| .recent-left { display: flex; align-items: center; gap: 12px; } | |
| .level-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; box-shadow: 0 0 6px currentColor; } | |
| .recent-label { font-size: .88rem; font-weight: 600; } | |
| .recent-date { font-size: .75rem; color: var(--muted); margin-top: 2px; } | |
| .recent-score { font-size: .9rem; font-weight: 700; } | |
| .empty-text { color: var(--muted); font-size: .9rem; text-align: center; padding: 24px 0; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| EMPTY STATE | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .empty-dashboard { | |
| text-align: center; padding: 80px 24px; | |
| background: var(--surface); border: 1px dashed var(--border2); | |
| border-radius: var(--r); | |
| } | |
| .empty-icon { font-size: 3.5rem; margin-bottom: 16px; display: block; } | |
| .empty-dashboard h3 { font-size: 1.25rem; font-weight: 700; margin-bottom: 8px; } | |
| .empty-dashboard p { color: var(--muted); margin-bottom: 24px; max-width: 360px; margin-left: auto; margin-right: auto; line-height: 1.6; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| ASSESSMENT FORM | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .section-card { margin-bottom: 20px; } | |
| .section-head { | |
| display: flex; align-items: flex-start; gap: 14px; | |
| margin-bottom: 20px; padding-bottom: 18px; border-bottom: 1px solid var(--border); | |
| } | |
| .section-head h3 { font-size: 1rem; font-weight: 600; color: var(--text); margin-bottom: 3px; } | |
| .section-icon-lg { font-size: 1.6rem; flex-shrink: 0; margin-top: 2px; } | |
| .section-desc { font-size: .85rem; color: var(--muted); } | |
| .badge-optional { margin-left: auto; padding: 3px 10px; border-radius: 20px; font-size: .73rem; font-weight: 600; | |
| background: rgba(100,116,139,.12); color: var(--muted); border: 1px solid rgba(100,116,139,.25); flex-shrink: 0; } | |
| /* Sliders */ | |
| .slider-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 18px; margin-bottom: 18px; } | |
| .slider-field { display: flex; flex-direction: column; gap: 6px; } | |
| .slider-header { display: flex; justify-content: space-between; align-items: center; } | |
| .slider-header label { font-size: .78rem; font-weight: 600; color: var(--muted2); text-transform: uppercase; letter-spacing: .05em; } | |
| .slider-value { font-size: .85rem; font-weight: 700; color: var(--accent); min-width: 48px; text-align: right; } | |
| .slider-range { display: flex; justify-content: space-between; font-size: .7rem; color: var(--muted); margin-top: 1px; } | |
| input[type=range] { | |
| -webkit-appearance: none; width: 100%; height: 4px; | |
| background: var(--border2); border-radius: 2px; outline: none; padding: 0; | |
| border: none; box-shadow: none; | |
| } | |
| input[type=range]::-webkit-slider-thumb { | |
| -webkit-appearance: none; width: 16px; height: 16px; | |
| background: linear-gradient(135deg, var(--accent), var(--accent2)); | |
| border-radius: 50%; cursor: pointer; | |
| box-shadow: 0 0 0 3px rgba(91,156,246,.2); | |
| transition: box-shadow var(--t); | |
| } | |
| input[type=range]::-webkit-slider-thumb:hover { box-shadow: 0 0 0 5px rgba(91,156,246,.3); } | |
| input[type=range]:focus { box-shadow: none; } | |
| .cat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 14px; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| RESULT PAGE | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .result-layout { display: grid; grid-template-columns: 1fr 360px; gap: 20px; align-items: start; } | |
| .result-main { text-align: center; } | |
| .result-side { } | |
| .result-actions { display: flex; gap: 12px; margin-top: 4px; flex-wrap: wrap; } | |
| /* Gauge */ | |
| .gauge-wrap { position: relative; width: 200px; height: 200px; margin: 12px auto 8px; } | |
| .gauge-svg { width: 100%; height: 100%; } | |
| .gauge-center { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; } | |
| .gauge-pct { font-size: 2.2rem; font-weight: 800; line-height: 1; } | |
| .gauge-lbl { font-size: .85rem; font-weight: 600; margin-top: 4px; text-transform: uppercase; letter-spacing: .06em; } | |
| /* Breakdown */ | |
| .breakdown-list { display: flex; flex-direction: column; gap: 8px; } | |
| .breakdown-item { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; background: var(--surface2); border-radius: var(--r-sm); } | |
| .breakdown-item--main { border: 1px solid var(--border2); background: var(--surface3); } | |
| .breakdown-key { font-size: .82rem; color: var(--muted); } | |
| .breakdown-right { display: flex; align-items: center; gap: 8px; } | |
| .breakdown-label { font-size: .88rem; font-weight: 600; } | |
| .breakdown-score { font-size: .82rem; color: var(--muted2); } | |
| .modality-badge { padding: 3px 10px; border-radius: 20px; font-size: .76rem; font-weight: 600; | |
| background: var(--surface3); color: var(--muted2); border: 1px solid var(--border); text-transform: capitalize; } | |
| .muted { color: var(--muted); } | |
| /* Advice box */ | |
| .advice-box { | |
| padding: 16px 18px; border-radius: var(--r-sm); | |
| border-left: 4px solid var(--accent); | |
| background: rgba(91,156,246,.07); | |
| font-size: .9rem; line-height: 1.7; color: var(--muted2); | |
| position: relative; | |
| } | |
| /* Detail grid */ | |
| .detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 14px; } | |
| .detail-item { background: var(--surface2); padding: 10px 14px; border-radius: var(--r-sm); } | |
| .detail-key { font-size: .74rem; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 3px; } | |
| .detail-val { font-size: .92rem; font-weight: 600; } | |
| .detail-note { margin-bottom: 12px; } | |
| .detail-note-label { font-size: .74rem; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 6px; font-weight: 600; } | |
| .detail-note p { background: var(--surface2); padding: 10px 14px; border-radius: var(--r-sm); font-size: .9rem; line-height: 1.6; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| DASHBOARD LAYOUT (main + activity side panel) | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .dash-layout { display: grid; grid-template-columns: 1fr 300px; gap: 20px; align-items: start; } | |
| .dash-main { min-width: 0; } | |
| .dash-side { position: sticky; top: 24px; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| ACTIVITY PANEL | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .activity-panel { padding: 20px; } | |
| .activity-list { display: flex; flex-direction: column; gap: 6px; } | |
| .activity-item { | |
| border-radius: var(--r-sm); | |
| overflow: hidden; | |
| border: 1px solid var(--border); | |
| transition: border-color var(--t); | |
| } | |
| .activity-item:hover { border-color: var(--ac, var(--accent)); } | |
| .activity-header { | |
| display: flex; align-items: center; gap: 10px; | |
| width: 100%; padding: 10px 12px; | |
| background: none; border: none; cursor: pointer; | |
| text-align: left; color: var(--text); | |
| } | |
| .activity-header:hover { background: var(--surface2); } | |
| .activity-icon { | |
| width: 34px; height: 34px; border-radius: 8px; flex-shrink: 0; | |
| display: flex; align-items: center; justify-content: center; | |
| font-size: 1rem; | |
| } | |
| .activity-meta { flex: 1; min-width: 0; } | |
| .activity-title { display: block; font-size: .88rem; font-weight: 600; color: var(--text); } | |
| .activity-dur { display: block; font-size: .73rem; color: var(--muted); margin-top: 1px; } | |
| .activity-chevron { | |
| font-size: 1.1rem; color: var(--muted); transition: transform var(--t); line-height: 1; | |
| } | |
| .activity-chevron--open { transform: rotate(90deg); color: var(--ac, var(--accent)); } | |
| .activity-steps { | |
| list-style: none; padding: 0 12px 12px 12px; | |
| background: var(--surface2); counter-reset: step; | |
| display: flex; flex-direction: column; gap: 6px; | |
| } | |
| .activity-steps li { | |
| counter-increment: step; | |
| font-size: .8rem; color: var(--muted2); line-height: 1.5; | |
| padding-left: 22px; position: relative; | |
| } | |
| .activity-steps li::before { | |
| content: counter(step); | |
| position: absolute; left: 0; | |
| width: 16px; height: 16px; border-radius: 50%; | |
| background: var(--ac, var(--accent)); color: #fff; | |
| font-size: .65rem; font-weight: 700; | |
| display: flex; align-items: center; justify-content: center; | |
| top: 1px; | |
| } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| HISTORY PAGE | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .history-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 16px; margin-bottom: 20px; } | |
| .history-card { | |
| background: var(--surface); border: 1px solid var(--border); | |
| border-radius: var(--r); padding: 18px; cursor: pointer; | |
| transition: border-color var(--t), transform var(--t), box-shadow var(--t); | |
| border-top: 3px solid var(--level-color, var(--border)); | |
| position: relative; overflow: hidden; | |
| } | |
| .history-card::after { | |
| content: ''; | |
| position: absolute; inset: 0; border-radius: var(--r); | |
| background: radial-gradient(ellipse at top left, rgba(91,156,246,.05) 0%, transparent 60%); | |
| pointer-events: none; opacity: 0; transition: opacity var(--t); | |
| } | |
| .history-card:hover { border-color: var(--level-color, var(--border2)); transform: translateY(-3px); box-shadow: 0 10px 36px rgba(0,0,0,.45); } | |
| .history-card:hover::after { opacity: 1; } | |
| .hc-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; } | |
| .hc-badge { padding: 4px 12px; border-radius: 20px; font-size: .8rem; font-weight: 700; } | |
| .hc-score { font-size: 1.3rem; font-weight: 800; color: var(--text); } | |
| .hc-bars { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; } | |
| .hc-bar-wrap { display: flex; flex-direction: column; gap: 3px; } | |
| .hc-bar-label{ font-size: .72rem; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; } | |
| .hc-bar-track{ height: 5px; background: var(--surface3); border-radius: 3px; overflow: hidden; } | |
| .hc-bar-fill { height: 100%; border-radius: 3px; transition: width 1s cubic-bezier(.4,0,.2,1); } | |
| .hc-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 6px; } | |
| .hc-modality { font-size: .73rem; color: var(--muted2); background: var(--surface2); padding: 2px 8px; border-radius: 10px; text-transform: capitalize; } | |
| .hc-date { font-size: .74rem; color: var(--muted); } | |
| /* Pagination */ | |
| .pagination { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 8px; } | |
| .page-btn { padding: 7px 14px; border: 1px solid var(--border); border-radius: var(--r-xs); background: var(--surface); color: var(--muted); font-size: .85rem; transition: var(--t); } | |
| .page-btn:hover, .page-btn--active { border-color: var(--accent); color: var(--accent); background: rgba(91,156,246,.08); } | |
| .page-btn:disabled { opacity: .4; cursor: not-allowed; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| MODAL | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .modal-overlay { | |
| position: fixed; inset: 0; z-index: 100; | |
| display: flex; align-items: center; justify-content: center; | |
| background: rgba(0,0,0,.75); backdrop-filter: blur(10px); | |
| animation: fadeIn .15s ease; | |
| } | |
| .modal-box { | |
| position: relative; background: var(--surface); | |
| border: 1px solid var(--border2); border-radius: var(--r); | |
| padding: 28px 30px; width: 90%; max-width: 520px; | |
| max-height: 85vh; overflow-y: auto; box-shadow: var(--sh), 0 0 60px rgba(0,0,0,.5); | |
| animation: slideUp .2s ease; | |
| } | |
| .modal-close { | |
| position: absolute; top: 14px; right: 16px; background: none; border: none; | |
| color: var(--muted); font-size: 1.1rem; | |
| width: 28px; height: 28px; border-radius: 50%; | |
| display: flex; align-items: center; justify-content: center; | |
| transition: background var(--t), color var(--t); | |
| } | |
| .modal-close:hover { color: var(--text); background: var(--surface2); } | |
| .modal-title { font-size: 1.15rem; font-weight: 700; margin-bottom: 16px; letter-spacing: -.01em; } | |
| @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } } | |
| @keyframes slideUp { from { transform: translateY(20px); opacity: 0; } to { transform: none; opacity: 1; } } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| MOBILE | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .sidebar-backdrop { display: none; } | |
| @media (max-width: 860px) { | |
| .main-area { padding-top: 56px; } | |
| .mobile-bar { display: flex; } | |
| .sidebar { position: fixed; left: -240px; top: 0; height: 100vh; z-index: 60; transition: left var(--t); } | |
| .sidebar--open { left: 0; box-shadow: var(--sh); } | |
| .sidebar-backdrop { display: block; position: fixed; inset: 0; z-index: 55; background: rgba(0,0,0,.5); } | |
| .stat-grid { grid-template-columns: repeat(2, 1fr); } | |
| .two-col { grid-template-columns: 1fr; } | |
| .result-layout { grid-template-columns: 1fr; } | |
| .page { padding: 20px 16px; } | |
| .history-grid { grid-template-columns: 1fr; } | |
| .detail-grid { grid-template-columns: 1fr; } | |
| /* Dashboard: stack side panel below main on tablet */ | |
| .dash-layout { grid-template-columns: 1fr; } | |
| .dash-side { position: static; } | |
| } | |
| @media (max-width: 480px) { | |
| .stat-grid { grid-template-columns: 1fr 1fr; } | |
| .slider-grid { grid-template-columns: 1fr; } | |
| .cat-grid { grid-template-columns: 1fr; } | |
| } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββ | |
| PROFILE PAGE | |
| βββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .profile-page { | |
| max-width: 720px; | |
| margin: 0 auto; | |
| padding: 32px 24px 60px; | |
| } | |
| .profile-header-bar { | |
| margin-bottom: 32px; | |
| } | |
| .profile-header-bar .page-title { | |
| font-size: 1.8rem; | |
| font-weight: 700; | |
| background: linear-gradient(135deg, var(--accent), var(--accent2)); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| margin-bottom: 4px; | |
| } | |
| .profile-header-bar .page-sub { | |
| color: var(--muted); | |
| font-size: .9rem; | |
| } | |
| .profile-form { display: flex; flex-direction: column; gap: 28px; } | |
| .profile-section { | |
| background: var(--surface); | |
| border: 1px solid var(--border); | |
| border-radius: 16px; | |
| padding: 24px; | |
| } | |
| .section-title { | |
| font-size: 1rem; | |
| font-weight: 600; | |
| color: var(--text); | |
| margin-bottom: 18px; | |
| letter-spacing: .03em; | |
| } | |
| /* Avatar upload */ | |
| .avatar-upload-row { | |
| display: flex; | |
| align-items: center; | |
| gap: 20px; | |
| flex-wrap: wrap; | |
| } | |
| .avatar-large { | |
| position: relative; | |
| width: 88px; | |
| height: 88px; | |
| border-radius: 50%; | |
| background: linear-gradient(135deg, #1a2840, #1e3060); | |
| border: 2px solid var(--border); | |
| cursor: pointer; | |
| overflow: hidden; | |
| flex-shrink: 0; | |
| transition: border-color .2s; | |
| } | |
| .avatar-large:hover { border-color: var(--accent); } | |
| .avatar-img { width: 100%; height: 100%; object-fit: cover; display: block; } | |
| .avatar-initials { | |
| position: absolute; | |
| inset: 0; | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| font-size: 1.6rem; | |
| font-weight: 700; | |
| color: var(--accent); | |
| letter-spacing: .05em; | |
| } | |
| .avatar-overlay { | |
| position: absolute; | |
| inset: 0; | |
| background: rgba(0,0,0,.5); | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| font-size: 1.3rem; | |
| opacity: 0; | |
| transition: opacity .2s; | |
| } | |
| .avatar-large:hover .avatar-overlay { opacity: 1; } | |
| .avatar-actions { | |
| display: flex; | |
| flex-direction: column; | |
| gap: 8px; | |
| align-items: flex-start; | |
| } | |
| .avatar-hint { font-size: .75rem; color: var(--muted); } | |
| .btn-ghost-danger { | |
| background: transparent; | |
| border: 1px solid #ef4444; | |
| color: #ef4444; | |
| padding: 6px 14px; | |
| border-radius: 8px; | |
| cursor: pointer; | |
| font-size: .82rem; | |
| transition: background .2s; | |
| } | |
| .btn-ghost-danger:hover { background: rgba(239,68,68,.1); } | |
| /* Profile grid (2-col) */ | |
| .profile-grid { | |
| display: grid; | |
| grid-template-columns: 1fr 1fr; | |
| gap: 16px; | |
| } | |
| @media (max-width: 540px) { .profile-grid { grid-template-columns: 1fr; } } | |
| .form-select { | |
| width: 100%; | |
| background: var(--bg); | |
| border: 1px solid var(--border); | |
| color: var(--text); | |
| border-radius: 10px; | |
| padding: 10px 12px; | |
| font-size: .88rem; | |
| outline: none; | |
| transition: border-color .2s; | |
| appearance: none; | |
| background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); | |
| background-repeat: no-repeat; | |
| background-position: right 12px center; | |
| padding-right: 36px; | |
| } | |
| .form-select:focus { border-color: var(--accent); } | |
| .form-select option { background: #0d1420; } | |
| .form-textarea { | |
| width: 100%; | |
| background: var(--bg); | |
| border: 1px solid var(--border); | |
| color: var(--text); | |
| border-radius: 10px; | |
| padding: 10px 12px; | |
| font-size: .88rem; | |
| font-family: inherit; | |
| resize: vertical; | |
| outline: none; | |
| transition: border-color .2s; | |
| box-sizing: border-box; | |
| } | |
| .form-textarea:focus { border-color: var(--accent); } | |
| .char-count { text-align: right; font-size: .75rem; color: var(--muted); margin-top: 4px; } | |
| .form-hint { color: var(--muted); font-size: .8rem; font-weight: 400; } | |
| /* Privacy card */ | |
| .profile-privacy {} | |
| .privacy-card { | |
| display: flex; | |
| align-items: flex-start; | |
| gap: 16px; | |
| background: rgba(91,156,246,.06); | |
| border: 1px solid rgba(91,156,246,.18); | |
| border-radius: 12px; | |
| padding: 16px; | |
| } | |
| .privacy-icon { font-size: 1.5rem; flex-shrink: 0; padding-top: 2px; } | |
| .privacy-text { flex: 1; } | |
| .privacy-text strong { display: block; margin-bottom: 4px; color: var(--text); font-size: .92rem; } | |
| .privacy-text p { font-size: .82rem; color: var(--muted); line-height: 1.5; margin: 0; } | |
| .anon-notice { | |
| margin-top: 12px; | |
| padding: 10px 14px; | |
| background: rgba(167,139,250,.08); | |
| border: 1px solid rgba(167,139,250,.25); | |
| border-radius: 10px; | |
| font-size: .83rem; | |
| color: var(--accent2); | |
| } | |
| /* Toggle switch */ | |
| .toggle-switch { display: inline-flex; cursor: pointer; flex-shrink: 0; margin-top: 4px; } | |
| .toggle-switch input { display: none; } | |
| .toggle-track { | |
| width: 44px; | |
| height: 24px; | |
| background: var(--border); | |
| border-radius: 999px; | |
| position: relative; | |
| transition: background .25s; | |
| } | |
| .toggle-switch input:checked + .toggle-track { background: var(--accent); } | |
| .toggle-thumb { | |
| position: absolute; | |
| top: 3px; | |
| left: 3px; | |
| width: 18px; | |
| height: 18px; | |
| background: #fff; | |
| border-radius: 50%; | |
| transition: transform .25s; | |
| box-shadow: 0 1px 4px rgba(0,0,0,.4); | |
| } | |
| .toggle-switch input:checked + .toggle-track .toggle-thumb { transform: translateX(20px); } | |
| /* Actions row */ | |
| .profile-actions { display: flex; justify-content: flex-end; gap: 12px; } | |
| /* Sidebar avatar img support */ | |
| .user-chip-link { | |
| display: flex; | |
| align-items: center; | |
| gap: 10px; | |
| text-decoration: none; | |
| color: inherit; | |
| width: 100%; | |
| border-radius: 10px; | |
| padding: 8px; | |
| transition: background .15s; | |
| } | |
| .user-chip-link:hover { background: rgba(255,255,255,.05); } | |
| .user-avatar--img { | |
| object-fit: cover; | |
| border-radius: 50%; | |
| width: 34px; | |
| height: 34px; | |
| flex-shrink: 0; | |
| } | |
| /* form-error / form-success (if not already defined) */ | |
| .form-error { color: #ef4444; font-size: .85rem; padding: 8px 12px; background: rgba(239,68,68,.08); border-radius: 8px; } | |
| .form-success { color: #22c55e; font-size: .85rem; padding: 8px 12px; background: rgba(34,197,94,.08); border-radius: 8px; } | |
| /* Sidebar brand link */ | |
| .sidebar-brand-link { | |
| display: flex; align-items: center; gap: 10px; | |
| text-decoration: none; color: inherit; | |
| border-radius: 10px; padding: 6px 8px; margin: -6px -8px; | |
| transition: background .15s; | |
| } | |
| .sidebar-brand-link:hover { background: rgba(255,255,255,.05); } | |
| .mobile-brand-link { text-decoration: none; color: inherit; font-weight: 600; font-size: 1rem; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββ | |
| BREATHE HUB PAGE | |
| βββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .breathe-hub { max-width: 960px; margin: 0 auto; padding: 32px 24px 60px; } | |
| .breathe-hub-actions { | |
| display: flex; | |
| gap: 10px; | |
| justify-content: center; | |
| flex-wrap: wrap; | |
| margin-top: 20px; | |
| } | |
| .breathe-back-btn { | |
| display: inline-flex; | |
| align-items: center; | |
| gap: 6px; | |
| color: var(--muted); | |
| text-decoration: none; | |
| font-size: .88rem; | |
| font-weight: 500; | |
| padding: 8px 20px; | |
| border: 1px solid var(--border); | |
| border-radius: 999px; | |
| transition: color .15s, border-color .15s, background .15s; | |
| } | |
| .breathe-back-btn:hover { | |
| color: var(--text); | |
| border-color: var(--accent); | |
| background: rgba(91,156,246,.07); | |
| } | |
| .breathe-hub-header { | |
| text-align: center; | |
| margin-bottom: 48px; | |
| } | |
| .breathe-hub-rings { | |
| position: relative; | |
| width: 100px; | |
| height: 100px; | |
| margin: 0 auto 20px; | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| } | |
| .hub-ring { | |
| position: absolute; | |
| border-radius: 50%; | |
| border: 2px solid var(--accent); | |
| opacity: .2; | |
| animation: hubPulse 3s ease-in-out infinite; | |
| } | |
| .hub-ring-1 { width: 60px; height: 60px; animation-delay: 0s; } | |
| .hub-ring-2 { width: 80px; height: 80px; animation-delay: .6s; opacity: .15; } | |
| .hub-ring-3 { width: 100px; height: 100px; animation-delay: 1.2s; opacity: .08; } | |
| @keyframes hubPulse { | |
| 0%, 100% { transform: scale(1); opacity: .2; } | |
| 50% { transform: scale(1.12); opacity: .35; } | |
| } | |
| .hub-glyph { width: 70px; height: 70px; object-fit: contain; position: relative; z-index: 1; } | |
| .breathe-hub-title { | |
| font-size: 2.8rem; | |
| font-weight: 900; | |
| letter-spacing: .2em; | |
| background: linear-gradient(135deg, var(--accent), var(--accent2), #f472b6); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| margin-bottom: 10px; | |
| } | |
| .breathe-hub-sub { color: var(--muted2); font-size: 1rem; max-width: 400px; margin: 0 auto; line-height: 1.6; } | |
| /* ββ Deep Breath Widget ββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .dbw { | |
| display: flex; | |
| flex-direction: column; | |
| align-items: center; | |
| gap: 20px; | |
| margin: 0 auto 52px; | |
| max-width: 340px; | |
| } | |
| .dbw-orb-wrap { | |
| position: relative; | |
| width: 180px; | |
| height: 180px; | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| } | |
| .dbw-orb { | |
| width: 110px; | |
| height: 110px; | |
| border-radius: 50%; | |
| background: radial-gradient(circle at 38% 38%, rgba(255,74,38,.22), rgba(123,74,190,.18)); | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| position: relative; | |
| z-index: 2; | |
| box-shadow: 0 0 32px rgba(123,74,190,.25), 0 0 64px rgba(255,74,38,.12); | |
| } | |
| .dbw-logo { | |
| width: 72px; | |
| height: 72px; | |
| object-fit: contain; | |
| pointer-events: none; | |
| user-select: none; | |
| } | |
| .dbw-ring { | |
| position: absolute; | |
| border-radius: 50%; | |
| border: 1.5px solid; | |
| z-index: 1; | |
| transition: transform 4s cubic-bezier(.4,0,.2,1), opacity .5s; | |
| } | |
| .dbw-ring-1 { | |
| width: 140px; height: 140px; | |
| border-color: rgba(232,92,136,.35); | |
| opacity: .4; | |
| } | |
| .dbw-ring-2 { | |
| width: 175px; height: 175px; | |
| border-color: rgba(123,74,190,.22); | |
| opacity: .25; | |
| } | |
| /* ring expansion matches orb phase */ | |
| .dbw-ring-1.dbw-ring--0 { transform: scale(1.18); opacity: .55; transition: transform 4s cubic-bezier(.4,0,.2,1); } | |
| .dbw-ring-2.dbw-ring--0 { transform: scale(1.12); opacity: .35; transition: transform 4s cubic-bezier(.4,0,.2,1); } | |
| .dbw-ring-1.dbw-ring--1 { transform: scale(1.18); opacity: .55; } | |
| .dbw-ring-2.dbw-ring--1 { transform: scale(1.12); opacity: .35; } | |
| .dbw-ring-1.dbw-ring--2 { transform: scale(1); opacity: .4; transition: transform 6s cubic-bezier(.4,0,.2,1); } | |
| .dbw-ring-2.dbw-ring--2 { transform: scale(1); opacity: .25; transition: transform 6s cubic-bezier(.4,0,.2,1); } | |
| .dbw-ring-1.dbw-ring--3 { transform: scale(1); opacity: .4; } | |
| .dbw-ring-2.dbw-ring--3 { transform: scale(1); opacity: .25; } | |
| .dbw-arc { | |
| position: absolute; | |
| top: 0; left: 0; | |
| width: 100%; height: 100%; | |
| z-index: 3; | |
| pointer-events: none; | |
| transition: stroke-dashoffset 1s linear; | |
| } | |
| .dbw-arc circle:nth-child(2) { transition: stroke-dashoffset 1s linear; } | |
| .dbw-info { text-align: center; } | |
| .dbw-phase { | |
| font-size: 1.2rem; | |
| font-weight: 700; | |
| letter-spacing: .12em; | |
| background: linear-gradient(135deg, #FF4A26, #7B4ABE); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| min-height: 1.5em; | |
| } | |
| .dbw-tick { | |
| font-size: 2.8rem; | |
| font-weight: 900; | |
| line-height: 1.1; | |
| color: var(--text); | |
| min-height: 1.1em; | |
| } | |
| .dbw-counter { | |
| font-size: .85rem; | |
| color: var(--muted2); | |
| margin-top: 4px; | |
| } | |
| .dbw-controls { display: flex; gap: 10px; } | |
| .dbw-btn { | |
| padding: 10px 28px; | |
| border-radius: 999px; | |
| border: none; | |
| font-size: .92rem; | |
| font-weight: 600; | |
| cursor: pointer; | |
| transition: opacity .15s, transform .1s; | |
| } | |
| .dbw-btn:active { transform: scale(.96); } | |
| .dbw-btn--start { | |
| background: linear-gradient(135deg, #FF4A26, #7B4ABE); | |
| color: #fff; | |
| } | |
| .dbw-btn--stop { | |
| background: rgba(255,74,38,.15); | |
| color: #FF4A26; | |
| border: 1px solid rgba(255,74,38,.4); | |
| } | |
| .dbw-btn--reset { | |
| background: var(--surface2); | |
| color: var(--muted); | |
| border: 1px solid var(--border); | |
| } | |
| /* ββ Box Breathing Page ββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .box-breathing-page { | |
| max-width: 540px; | |
| margin: 0 auto; | |
| padding: 40px 24px 60px; | |
| display: flex; | |
| flex-direction: column; | |
| align-items: center; | |
| } | |
| .box-breathing-header { | |
| text-align: center; | |
| margin-bottom: 36px; | |
| width: 100%; | |
| } | |
| .box-breathing-title { | |
| font-size: 2rem; | |
| font-weight: 900; | |
| letter-spacing: .18em; | |
| background: linear-gradient(135deg, #FF4A26, #7B4ABE); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| margin: 12px 0 8px; | |
| } | |
| .box-breathing-sub { | |
| color: var(--muted2); | |
| font-size: .92rem; | |
| line-height: 1.6; | |
| } | |
| .box-breathing-tips { | |
| display: grid; | |
| grid-template-columns: 1fr 1fr; | |
| gap: 12px; | |
| width: 100%; | |
| margin-top: 8px; | |
| } | |
| .bbt-card { | |
| display: flex; | |
| align-items: flex-start; | |
| gap: 12px; | |
| background: var(--surface2); | |
| border: 1px solid var(--border); | |
| border-radius: var(--r); | |
| padding: 14px 16px; | |
| } | |
| .bbt-icon { font-size: 1.5rem; flex-shrink: 0; } | |
| .bbt-label { font-size: .85rem; font-weight: 700; color: var(--text); margin-bottom: 2px; } | |
| .bbt-desc { font-size: .78rem; color: var(--muted2); line-height: 1.4; } | |
| @media (max-width: 420px) { | |
| .box-breathing-tips { grid-template-columns: 1fr; } | |
| } | |
| /* Cards grid */ | |
| .breathe-cards { | |
| display: grid; | |
| grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); | |
| gap: 16px; | |
| } | |
| .breathe-card { | |
| background: var(--surface); | |
| border: 1px solid var(--border); | |
| border-radius: 18px; | |
| padding: 22px 20px; | |
| text-align: left; | |
| cursor: pointer; | |
| transition: transform .2s, border-color .2s, box-shadow .2s; | |
| display: flex; | |
| flex-direction: column; | |
| gap: 12px; | |
| position: relative; | |
| overflow: hidden; | |
| } | |
| .breathe-card::before { | |
| content: ''; | |
| position: absolute; | |
| top: 0; left: 0; right: 0; | |
| height: 3px; | |
| background: var(--cc, var(--accent)); | |
| opacity: 0; | |
| transition: opacity .2s; | |
| } | |
| .breathe-card::after { | |
| content: ''; | |
| position: absolute; | |
| inset: 0; border-radius: 18px; | |
| background: radial-gradient(ellipse at top left, color-mix(in srgb, var(--cc, var(--accent)) 15%, transparent) 0%, transparent 65%); | |
| pointer-events: none; | |
| opacity: 0; | |
| transition: opacity .2s; | |
| } | |
| .breathe-card:hover { | |
| transform: translateY(-4px); | |
| border-color: var(--cc, var(--accent)); | |
| box-shadow: 0 10px 36px rgba(0,0,0,.4), 0 0 0 1px var(--cc, var(--accent))33; | |
| } | |
| .breathe-card:hover::before { opacity: 1; } | |
| .breathe-card:hover::after { opacity: 1; } | |
| .bc-icon { | |
| width: 52px; height: 52px; | |
| border-radius: 14px; | |
| display: flex; align-items: center; justify-content: center; | |
| font-size: 1.5rem; | |
| flex-shrink: 0; | |
| position: relative; z-index: 1; | |
| } | |
| .bc-body { flex: 1; position: relative; z-index: 1; } | |
| .bc-title { font-size: 1.05rem; font-weight: 700; color: var(--text); margin-bottom: 2px; } | |
| .bc-tagline { font-size: .8rem; color: var(--muted); margin-bottom: 8px; font-style: italic; } | |
| .bc-desc { font-size: .84rem; color: var(--muted2); line-height: 1.6; margin: 0; } | |
| .bc-local-note { | |
| display: block; | |
| margin-top: 8px; | |
| font-size: .76rem; | |
| color: var(--success); | |
| background: rgba(45,212,165,.08); | |
| padding: 4px 10px; | |
| border-radius: 6px; | |
| border: 1px solid rgba(45,212,165,.2); | |
| } | |
| .bc-badge { | |
| display: inline-flex; | |
| align-items: center; | |
| gap: 5px; | |
| font-size: .72rem; | |
| font-weight: 600; | |
| padding: 4px 10px; | |
| border-radius: 999px; | |
| border: 1px solid; | |
| width: fit-content; | |
| position: relative; z-index: 1; | |
| letter-spacing: .02em; | |
| } | |
| /* Guided modal */ | |
| .guided-modal { max-width: 460px; padding: 40px 36px; } | |
| .guided-header { text-align: center; margin-bottom: 24px; } | |
| .guided-icon { font-size: 2.8rem; display: block; margin-bottom: 10px; } | |
| .guided-header h2 { font-size: 1.4rem; font-weight: 800; margin: 0; letter-spacing: -.01em; } | |
| .guided-progress { | |
| display: flex; gap: 7px; justify-content: center; margin-bottom: 32px; | |
| } | |
| .progress-dot { | |
| width: 8px; height: 8px; border-radius: 50%; | |
| background: var(--border2); | |
| transition: background .2s, transform .2s, width .2s; | |
| } | |
| .progress-dot--active { transform: scale(1.4); width: 20px; border-radius: 4px; } | |
| .progress-dot--done { opacity: .8; } | |
| .guided-step { text-align: center; min-height: 90px; margin-bottom: 32px; padding: 0 8px; } | |
| .guided-step-label { font-size: 1.15rem; font-weight: 700; margin-bottom: 12px; } | |
| .guided-step-desc { color: var(--muted2); font-size: .93rem; line-height: 1.65; } | |
| .guided-actions { display: flex; gap: 10px; justify-content: center; } | |
| .btn-outline { | |
| display: inline-flex; align-items: center; gap: 6px; | |
| padding: 10px 22px; border: 1px solid var(--border2); border-radius: var(--r-sm); | |
| background: transparent; color: var(--muted2); font-size: .9rem; font-weight: 500; | |
| cursor: pointer; transition: var(--t); | |
| } | |
| .btn-outline:hover { color: var(--text); border-color: var(--border2); background: var(--surface2); } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββ | |
| GRATITUDE JOURNAL PAGE | |
| βββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .gratitude-page { max-width: 840px; margin: 0 auto; padding: 32px 24px 60px; } | |
| .tab-toggle { | |
| display: flex; | |
| gap: 4px; | |
| background: var(--bg); | |
| border: 1px solid var(--border); | |
| border-radius: 12px; | |
| padding: 4px; | |
| flex-shrink: 0; | |
| } | |
| .tab-btn { | |
| padding: 8px 18px; | |
| border-radius: 9px; | |
| border: none; | |
| background: transparent; | |
| color: var(--muted); | |
| font-size: .87rem; | |
| cursor: pointer; | |
| display: flex; align-items: center; gap: 6px; | |
| transition: background .2s, color .2s; | |
| white-space: nowrap; | |
| } | |
| .tab-btn--active { | |
| background: linear-gradient(135deg, var(--accent), var(--accent2)); | |
| color: #fff; font-weight: 600; | |
| box-shadow: 0 2px 10px rgba(91,156,246,.35); | |
| } | |
| .tab-count { | |
| background: rgba(255,255,255,.18); | |
| border-radius: 999px; | |
| padding: 1px 7px; | |
| font-size: .73rem; | |
| } | |
| .gratitude-write { display: flex; flex-direction: column; gap: 18px; } | |
| .gratitude-card {} | |
| .gratitude-items { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; } | |
| .gratitude-item-row { display: flex; align-items: center; gap: 10px; } | |
| .gratitude-num { font-size: 1.1rem; font-weight: 700; color: var(--accent); width: 20px; flex-shrink: 0; } | |
| .gratitude-input { flex: 1; } | |
| .gratitude-mood-row { margin-top: 4px; } | |
| .mood-grid { | |
| display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; | |
| } | |
| .mood-btn { | |
| display: flex; flex-direction: column; align-items: center; gap: 3px; | |
| padding: 10px 14px; | |
| background: var(--bg); | |
| border: 1px solid var(--border); | |
| border-radius: 12px; | |
| cursor: pointer; | |
| transition: border-color .15s, background .15s, transform .15s; | |
| min-width: 60px; | |
| } | |
| .mood-btn:hover { transform: translateY(-2px); border-color: var(--border2); } | |
| .mood-btn--active { border-color: var(--accent); background: rgba(91,156,246,.12); transform: translateY(-2px); } | |
| .mood-emoji { font-size: 1.4rem; } | |
| .mood-label { font-size: .7rem; color: var(--muted); } | |
| .mood-btn--active .mood-label { color: var(--accent); font-weight: 600; } | |
| .gratitude-actions { display: flex; gap: 10px; margin-top: 8px; } | |
| .gratitude-tips { background: rgba(251,191,36,.05); border-color: rgba(251,191,36,.2); } | |
| .tips-list { margin: 0; padding-left: 20px; color: var(--muted); font-size: .85rem; line-height: 1.9; } | |
| /* Entry grid */ | |
| .gratitude-history {} | |
| .gentry-grid { | |
| display: grid; | |
| grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); | |
| gap: 16px; | |
| } | |
| .gentry-card { | |
| padding: 18px; | |
| transition: border-color var(--t), transform var(--t), box-shadow var(--t); | |
| border-left: 3px solid var(--accent2) ; | |
| } | |
| .gentry-card:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,.35); } | |
| .gentry-header { | |
| display: flex; align-items: center; gap: 8px; | |
| margin-bottom: 12px; flex-wrap: wrap; | |
| } | |
| .gentry-date { font-size: .77rem; color: var(--muted); flex: 1; } | |
| .gentry-mood { font-size: .78rem; background: rgba(91,156,246,.1); color: var(--accent); padding: 3px 9px; border-radius: 999px; } | |
| .gentry-delete { background: none; border: none; cursor: pointer; font-size: .9rem; opacity: .5; transition: opacity .15s; } | |
| .gentry-delete:hover { opacity: 1; } | |
| .gentry-items { margin: 0 0 10px; padding-left: 18px; color: var(--text); font-size: .85rem; line-height: 1.8; } | |
| .gentry-content { font-size: .85rem; color: var(--muted); line-height: 1.6; margin: 0 0 6px; white-space: pre-wrap; } | |
| .gentry-content--clamp { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; } | |
| .gentry-expand { background: none; border: none; color: var(--accent); font-size: .78rem; cursor: pointer; padding: 0; } | |
| .pagination { | |
| display: flex; align-items: center; justify-content: center; gap: 16px; margin-top: 28px; | |
| } | |
| .page-info { font-size: .85rem; color: var(--muted); } | |
| .empty-state { | |
| text-align: center; padding: 60px 20px; | |
| } | |
| .empty-state .empty-icon { font-size: 2.8rem; margin-bottom: 12px; } | |
| .empty-state h3 { font-size: 1.1rem; color: var(--text); margin-bottom: 6px; } | |
| .empty-state p { color: var(--muted); font-size: .9rem; margin-bottom: 20px; } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββ | |
| TO-DO PAGE | |
| βββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .todo-page { max-width: 680px; margin: 0 auto; padding: 32px 24px 60px; } | |
| .local-storage-notice { | |
| display: flex; | |
| align-items: flex-start; | |
| gap: 12px; | |
| background: rgba(45,212,165,.06); | |
| border: 1px solid rgba(45,212,165,.25); | |
| border-radius: 12px; | |
| padding: 14px 16px; | |
| margin-bottom: 20px; | |
| } | |
| .lsn-icon { font-size: 1.4rem; flex-shrink: 0; } | |
| .local-storage-notice strong { display: block; color: #2dd4a5; font-size: .88rem; margin-bottom: 2px; } | |
| .local-storage-notice p { font-size: .78rem; color: var(--muted); margin: 0; line-height: 1.5; } | |
| .todo-add-card { padding: 18px; } | |
| .todo-add-row { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; } | |
| .todo-input { flex: 1; min-width: 200px; } | |
| .todo-add-btn { flex-shrink: 0; } | |
| .todo-priority-select { display: flex; gap: 6px; flex-wrap: wrap; } | |
| .priority-pill { | |
| padding: 5px 12px; | |
| border-radius: 999px; | |
| border: 1px solid var(--border); | |
| background: transparent; | |
| color: var(--muted); | |
| font-size: .78rem; | |
| cursor: pointer; | |
| transition: all .15s; | |
| white-space: nowrap; | |
| } | |
| .todo-meta-row { | |
| display: flex; align-items: center; gap: 12px; flex-wrap: wrap; | |
| margin: 16px 0; | |
| } | |
| .todo-stats { display: flex; gap: 8px; align-items: center; flex: 1; } | |
| .todo-stat { font-size: .82rem; color: var(--muted); } | |
| .todo-stat-sep { color: var(--border); } | |
| .todo-filters { display: flex; gap: 4px; } | |
| .filter-pill { | |
| padding: 4px 12px; border-radius: 999px; | |
| border: 1px solid var(--border); background: transparent; | |
| color: var(--muted); font-size: .78rem; cursor: pointer; | |
| transition: all .15s; | |
| } | |
| .filter-pill--active { background: var(--accent); border-color: var(--accent); color: #fff; } | |
| .todo-list { display: flex; flex-direction: column; gap: 8px; } | |
| .todo-item { | |
| display: flex; align-items: center; gap: 12px; | |
| background: var(--surface); | |
| border: 1px solid var(--border); | |
| border-radius: 12px; | |
| padding: 12px 14px; | |
| transition: border-color var(--t), opacity var(--t), transform var(--t); | |
| } | |
| .todo-item:hover { border-color: var(--border2); transform: translateX(3px); } | |
| .todo-item--done { opacity: .5; } | |
| .todo-item--done:hover { transform: none; } | |
| .todo-check { | |
| width: 22px; height: 22px; border-radius: 50%; | |
| border: 2px solid var(--border2); | |
| background: transparent; | |
| cursor: pointer; | |
| flex-shrink: 0; | |
| display: flex; align-items: center; justify-content: center; | |
| transition: background .15s, border-color .15s, transform .15s; | |
| } | |
| .todo-check:hover { border-color: var(--success); transform: scale(1.1); } | |
| .check-tick { color: #fff; font-size: .75rem; font-weight: 700; } | |
| .todo-text-col { flex: 1; min-width: 0; } | |
| .todo-text { | |
| display: block; font-size: .88rem; color: var(--text); | |
| word-break: break-word; | |
| } | |
| .todo-item--done .todo-text { text-decoration: line-through; } | |
| .todo-created { font-size: .72rem; color: var(--muted); } | |
| .todo-pri-dot { | |
| width: 8px; height: 8px; border-radius: 50%; | |
| flex-shrink: 0; | |
| } | |
| .todo-delete { | |
| background: none; border: none; cursor: pointer; | |
| font-size: .85rem; opacity: .4; flex-shrink: 0; | |
| transition: opacity .15s; | |
| } | |
| .todo-delete:hover { opacity: 1; } | |
| @media (max-width: 600px) { | |
| .breathe-cards { grid-template-columns: 1fr; } | |
| .gentry-grid { grid-template-columns: 1fr; } | |
| .tab-toggle { flex-wrap: wrap; } | |
| } | |