@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap";:root{--bg-page:#f4f6f8;--bg-card:#fff;--bg-sidebar:#fff;--text:#3d4451;--text-muted:#6b7280;--text-heading:#1a1f2e;--border:#e8ecf0;--shadow-sm:0 1px 3px #0f172a0f;--shadow-md:0 8px 24px #0f172a14;--radius:14px;--radius-lg:20px;--teal:#0d9488;--teal-soft:#0d94881f;--teal-dark:#0f766e;--accent-blue:#3b82f6;--accent-blue-soft:#3b82f61f;--accent-amber:#f59e0b;--accent-amber-soft:#f59e0b26;--accent-green:#10b981;--accent-green-soft:#10b9811f;--accent-violet:#8b5cf6;--accent-violet-soft:#8b5cf61f;--font-sans:"Plus Jakarta Sans", system-ui, sans-serif;--font-display:"Outfit", system-ui, sans-serif}*,:before,:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-sans);color:var(--text);background:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:var(--font-display)}#root{text-align:left;border:none;width:100%;max-width:none;min-height:100vh;margin:0}button{cursor:pointer;font-family:inherit}input{font-family:inherit}.dashboard{width:100%;min-height:100vh;display:flex}.login-screen{background:linear-gradient(150deg,#f8fafc 0%,#eef2ff 45%,#ecfdf5 100%);place-items:center;width:100%;min-height:100vh;padding:1.4rem;display:grid;position:relative;overflow:hidden}.login-backdrop-orb{pointer-events:none;border-radius:999px;position:absolute}.login-backdrop-orb--one{background:radial-gradient(circle at 30% 30%,#22c55e4d,#22c55e0d);width:330px;height:330px;top:-90px;right:-90px}.login-backdrop-orb--two{background:radial-gradient(circle at 30% 30%,#38bdf84d,#38bdf80d);width:320px;height:320px;bottom:-95px;left:-95px}.login-card{z-index:2;background:#fff;border:1px solid #dbe4ea;border-radius:24px;grid-template-columns:minmax(0,1fr) minmax(360px,.92fr);width:min(920px,100%);min-height:560px;display:grid;position:relative;overflow:hidden;box-shadow:0 26px 58px #0f172a29}.login-brand{margin-bottom:.9rem}.login-brand strong{letter-spacing:.1em;color:#22a767;align-items:center;font-size:1.04rem;font-weight:800;display:flex}.login-brand span{color:#64748b;letter-spacing:.03em;margin-top:.25rem;font-size:.76rem;font-weight:700;display:block}.login-left{flex-direction:column;justify-content:center;padding:2.1rem 2.1rem 1.8rem;display:flex}.login-card h1{color:#0f172a;margin:.1rem 0 .45rem;font-size:clamp(2rem,4vw,2.55rem);line-height:1.1}.login-card p{color:#64748b;max-width:420px;margin:0 0 1.2rem;font-size:.92rem}.login-form{gap:.65rem;display:grid}.login-form label{color:#4b5563;font-size:.78rem;font-weight:600}.login-input-wrap{background:#fff;border:1px solid #d1d5db;border-radius:10px;align-items:center;gap:.5rem;padding:.6rem .7rem;transition:border-color .16s,box-shadow .16s;display:flex}.login-input-wrap:focus-within{border-color:#22a767;box-shadow:0 0 0 3px #22a76721}.login-input-wrap svg{color:#64748b;flex-shrink:0}.login-input-wrap input{color:#0f172a;background:0 0;border:none;outline:none;width:100%;font-size:.88rem}.login-password-toggle{color:#64748b;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.login-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:.45rem .55rem;font-size:.76rem;font-weight:600}.login-submit-btn{background:linear-gradient(135deg,#67c587 0%,#43ad66 100%);border-radius:999px;justify-content:center;width:100%;margin-top:.55rem;padding:.78rem 1rem;font-size:.92rem;box-shadow:0 12px 26px #22a76747}.login-signup-hint{text-align:center;color:#64748b;margin-top:.95rem;font-size:.78rem}.login-signup-hint span{color:#1f2937;font-weight:700}.login-right{background:linear-gradient(165deg,#42bb70 0%,#33aa64 100%);flex-direction:column;justify-content:space-between;padding:1.2rem 1.1rem 1rem;display:flex}.login-illustration-wrap{background:#ffffff1a;border:1px solid #ffffff40;border-radius:16px;overflow:hidden}.login-illustration-wrap img{object-fit:cover;width:100%;height:310px;display:block}.login-illustration-wrap p{color:#f0fdf4;text-align:center;margin:0;padding:.7rem .75rem .8rem;font-size:.82rem;font-style:italic}.login-right-features{grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;margin-top:.8rem;display:grid}.login-feature-chip{color:#f0fdf4;background:#ffffff29;border:1px solid #ffffff52;border-radius:12px;justify-content:center;align-items:center;gap:.35rem;padding:.7rem .5rem;font-size:.74rem;font-weight:700;display:flex}@media (width<=900px){.login-card{grid-template-columns:1fr;min-height:auto}.login-left{padding:1.35rem 1.2rem 1.1rem}.login-right{padding:.9rem .9rem .95rem}.login-illustration-wrap img{height:220px}}.sidebar{z-index:100;-webkit-overflow-scrolling:touch;background:linear-gradient(#fbfcfd 0%,#f4f7fa 100%);border-right:1px solid #d8e1e8;flex-direction:column;flex-shrink:0;width:272px;height:100vh;max-height:100vh;padding:1.1rem 0 .75rem;display:flex;position:fixed;top:0;left:0;overflow:hidden auto;box-shadow:0 10px 32px #0f172a14}.sidebar-top{flex-direction:column;flex:1;min-height:0;display:flex}.sidebar-profile{border-top:1px solid var(--border);background:linear-gradient(#fafbfc 0%,#f4f6f8 100%);align-items:center;gap:.75rem;margin-top:auto;padding:1rem 1.25rem;display:flex}.sidebar-profile-avatar{object-fit:cover;width:44px;height:44px;box-shadow:var(--shadow-sm);border:2px solid #fff;border-radius:50%;flex-shrink:0}.sidebar-profile-meta{min-width:0}.sidebar-profile-meta strong{color:var(--text-heading);font-size:.875rem;font-weight:700;line-height:1.25;display:block}.sidebar-profile-meta span{color:var(--text-muted);font-size:.72rem;line-height:1.3}.sidebar-brand{border-bottom:1px solid #dbe4ea;margin-bottom:.95rem;padding:0 1.35rem 1.1rem}.sidebar-brand-top{align-items:center;gap:.65rem;display:flex}.sidebar-school-logo{color:#fff;text-transform:uppercase;cursor:pointer;background:linear-gradient(135deg,#14b8a6 0%,#0ea5e9 100%);border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.95rem;font-weight:800;display:inline-flex;box-shadow:0 8px 16px #0ea5e938}.sidebar-school-logo-img{object-fit:cover;border-radius:inherit;width:100%;height:100%}.sidebar-school-logo:hover{filter:brightness(1.03)}.sidebar-school-logo:focus-visible{outline-offset:2px;outline:2px solid #0ea5e9}.sidebar-brand h1{font-family:var(--font-display);color:var(--text-heading);letter-spacing:-.02em;margin:0 0 .25rem;font-size:1.15rem;font-weight:700}.sidebar-school-title{font-family:var(--font-display);color:#0f172a;letter-spacing:-.015em;margin:0;font-size:1.18rem;font-weight:800;line-height:1.25}.sidebar-brand-hint{color:#64748b;margin:.45rem 0 0;font-size:.68rem;font-weight:600}.school-brand-modal{max-width:420px}.school-brand-modal input[type=file]{background:#f8fafc;padding:.45rem .55rem}.school-logo-preview-wrap{align-items:center;gap:.6rem;margin-top:.45rem;display:flex}.school-logo-preview{object-fit:cover;border:1px solid #d1d5db;border-radius:10px;width:42px;height:42px}.counselor-chat-fab{z-index:220;cursor:pointer;background:#fff;border:2px solid #93c5fd;border-radius:999px;justify-content:center;align-items:center;width:62px;height:62px;padding:0;display:inline-flex;position:fixed;bottom:1.2rem;right:1.2rem;box-shadow:0 14px 30px #1e40af38}.counselor-chat-fab:hover{transform:translateY(-2px)}.counselor-chat-fab-icon{object-fit:contain;width:36px;height:36px}.counselor-chat-panel{z-index:230;-webkit-backdrop-filter:blur(12px);opacity:0;pointer-events:none;background:linear-gradient(145deg,#ffffff9e 0%,#f4f7ff80 100%);border:1px solid #ffffff6b;border-radius:22px;flex-direction:column;width:min(400px,100vw - 1.6rem);height:min(640px,100vh - 2.2rem);transition:transform .28s,opacity .28s;display:flex;position:fixed;bottom:1.1rem;right:1.1rem;overflow:hidden;transform:translate(120%);box-shadow:0 24px 60px #0f172a40}.counselor-chat-panel.is-open{opacity:1;pointer-events:auto;transform:translate(0)}.counselor-chat-header{background:#ffffff59;border-bottom:1px solid #94a3b847;justify-content:space-between;align-items:center;gap:.8rem;padding:.95rem 1rem;display:flex}.counselor-chat-header-meta strong{color:#0f172a;font-size:.94rem;display:block}.counselor-chat-header-meta span{color:#475569;font-size:.72rem;font-weight:600}.counselor-chat-close{color:#334155;cursor:pointer;background:#f1f5f9d9;border:none;border-radius:999px;width:34px;height:34px;font-size:1rem}.counselor-chat-feed{flex-direction:column;flex:1;gap:.6rem;padding:.9rem;display:flex;overflow-y:auto}.counselor-chat-bubble{border-radius:16px;max-width:85%;padding:.6rem .75rem;font-size:.84rem;line-height:1.45}.counselor-chat-bubble.is-counselor{color:#1f2937;background:#ffffffdb;border:1px solid #cbd5e1bf;align-self:flex-start}.counselor-chat-bubble.is-user{color:#f8fafc;background:linear-gradient(135deg,#6366f1 0%,#4f46e5 100%);align-self:flex-end}.counselor-chat-input-row{background:#fff6;border-top:1px solid #94a3b840;align-items:flex-end;gap:.55rem;padding:.8rem;display:flex}.counselor-chat-input-row textarea{resize:vertical;background:#ffffffeb;border:1px solid #cbd5e1;border-radius:12px;outline:none;flex:1;min-height:46px;max-height:130px;padding:.55rem .65rem;font-size:.82rem}.hapminds-logo-img{object-fit:contain;object-position:left center;height:auto;display:block}.header-hapminds-logo{max-width:min(200px,42vw);max-height:40px}.dash-hero-logo{max-width:280px;max-height:48px;margin:.35rem 0 .75rem}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.sidebar-brand span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.nav-section{background:#ffffffb8;border:1px solid #e3eaf0;border-radius:16px;margin:0 .55rem;padding:.2rem .75rem .45rem;box-shadow:0 6px 20px #0f172a0a}.nav-label{text-transform:uppercase;letter-spacing:.12em;color:#64748b;margin:.35rem 0 .42rem;padding:0 .7rem;font-size:.7rem;font-weight:700}.nav-item{color:#374151;text-align:left;background:0 0;border:none;border-radius:12px;align-items:center;gap:.72rem;width:100%;padding:.76rem .85rem;font-size:.92rem;font-weight:600;text-decoration:none;transition:background .18s,color .18s,transform .18s,box-shadow .18s;display:flex}.nav-item:hover{color:#0f172a;background:#f1f6f8;text-decoration:none;transform:translate(2px);box-shadow:0 4px 14px #0f172a12}.nav-item.active{color:#0f766e;background:#d8ecec;text-decoration:none;box-shadow:inset 0 0 0 1px #0f766e26}.nav-item svg{stroke-width:2.1px;opacity:.95;color:#64748b;flex-shrink:0;width:18px;height:18px;transition:color .18s,transform .18s}.nav-item:hover svg{color:#0f766e;transform:scale(1.04)}.nav-item.active svg{color:#0f766e}.mobile-bottom-nav{display:none}.main-wrap{flex-direction:column;flex:1;width:calc(100% - 272px);min-width:0;min-height:100vh;max-height:100vh;margin-left:272px;display:flex;overflow:hidden}.main-sticky-bar{background:var(--bg-page);border-bottom:1px solid #0f172a0f;flex-shrink:0;padding-top:1rem}.main-scroll{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden auto}.header-bar{border-radius:var(--radius-lg);background:linear-gradient(165deg,#e8ecef 0%,#eef2f5 45%,#e9eef2 100%);border:1px solid #0f172a0f;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin:0 1.5rem;padding:.875rem 1.35rem;display:flex;box-shadow:0 1px 2px #0f172a0a,0 8px 24px #0f172a0f}.header-left{flex:1;min-width:180px}.header-search-pill{color:#9ca3af;background:#fff;border:1px solid #0f172a0f;border-radius:999px;align-items:center;gap:.5rem;padding:.55rem 1rem;display:flex}.header-search-pill input{color:var(--text-heading);background:0 0;border:none;outline:none;flex:1;font-size:.9rem}.header-search-pill input::placeholder{color:#9ca3af}.header-logo-block{align-items:center;gap:1rem;min-width:0;display:flex}.header-logo-block img{object-fit:cover;border-radius:14px;flex-shrink:0;width:48px;height:48px;box-shadow:0 2px 8px #0d948826}.header-logo-block .titles h2{color:var(--text-heading);font-size:1.08rem;font-weight:700;font-family:var(--font-display);letter-spacing:-.02em;margin:0;line-height:1.2}.header-logo-block .titles p{color:var(--text-muted);margin:.15rem 0 0;font-size:.78rem;font-weight:500}.header-actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.5rem;display:flex}.header-user{border-left:1px solid var(--border);align-items:center;gap:.65rem;margin-left:.75rem;padding-left:1rem;display:flex}.header-user img{background:var(--teal-soft);border-radius:50%;width:40px;height:40px}.header-user .meta strong{color:var(--text-heading);font-size:.85rem;display:block}.header-user .meta span{color:var(--text-muted);font-size:.75rem}.header-user-status{background:#22c55e;border:2px solid #e5f9f0;border-radius:999px;width:10px;height:10px;margin-left:.15rem}.header-hapminds-cta{cursor:pointer;background:0 0;border:none;margin-left:.35rem;padding:0}.header-hapminds-cta .header-hapminds-logo{max-height:40px}.header-actions-icons{border-right:1px solid #0f172a14;align-items:center;gap:.35rem;margin-right:.25rem;padding-right:1rem;display:flex}.icon-btn{color:#475569;background:#ffffff73;border:1px solid #0f172a14;border-radius:11px;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s,border-color .15s,color .15s;display:flex}.icon-btn:hover{color:#0f766e;background:#ffffffd9;border-color:#0d948833}.header-hapminds{background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;margin:0;padding:0;display:flex}.header-hapminds-logo{mix-blend-mode:multiply;opacity:.98;width:auto;max-width:min(180px,38vw);height:auto;max-height:36px;display:block}@media (width<=900px){.header-hapminds-logo{mix-blend-mode:normal;opacity:1}}.toolbar{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#eef1f4;flex-wrap:wrap;align-items:center;gap:.75rem;margin:.75rem 1.5rem 1rem;padding:1rem 1.5rem;display:flex}.search-wrap{border:1px solid var(--border);background:#fff;border-radius:12px;flex:1;align-items:center;gap:.5rem;min-width:200px;padding:.55rem 1rem;display:flex}.search-wrap input{background:0 0;border:none;outline:none;flex:1;font-size:.9rem}.search-wrap input::placeholder{color:#9ca3af}.btn-filter{border:1px solid var(--border);width:44px;height:44px;color:var(--text);background:#fff;border-radius:12px}.btn-primary{background:var(--teal);color:#fff;border:none;border-radius:12px;align-items:center;gap:.4rem;padding:.6rem 1.1rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary:hover{background:var(--teal-dark)}.btn-outline{border:1px solid var(--border);color:var(--text-heading);background:#fff;border-radius:10px;padding:.5rem 1rem;font-size:.85rem;font-weight:500}.content-area{flex:1;min-height:min-content;padding:0 1.5rem 1.5rem}.page-title{font-family:var(--font-display);color:var(--text-heading);margin:0 0 .35rem;font-size:1.35rem;font-weight:700}.page-desc{color:var(--text-muted);margin:0 0 1.25rem;font-size:.9rem}.section-block{margin-bottom:2rem}.section-block h3{color:var(--text-heading);align-items:center;gap:.5rem;margin:0 0 1rem;font-size:.95rem;font-weight:600;display:flex}.card-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow .2s;overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.card-media{aspect-ratio:16/10;background:linear-gradient(145deg, var(--teal-soft), #e0f2f1);position:relative}.card-media img{object-fit:cover;width:100%;height:100%}.play-badge{opacity:0;background:#00000040;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.card:hover .play-badge{opacity:1}.play-badge span{background:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.2rem;display:flex}.card-body{padding:1rem 1.1rem}.card-body h4{color:var(--text-heading);margin:0 0 .35rem;font-size:.95rem;font-weight:600}.card-meta{color:var(--text-muted);margin-bottom:.5rem;font-size:.8rem}.pill{border-radius:999px;padding:.2rem .55rem;font-size:.7rem;font-weight:600;display:inline-block}.pill-teal{background:var(--teal-soft);color:var(--teal-dark)}.pill-blue{background:var(--accent-blue-soft);color:#1d4ed8}.pill-green{background:var(--accent-green-soft);color:#047857}.pill-amber{background:var(--accent-amber-soft);color:#b45309}.pill-violet{background:var(--accent-violet-soft);color:#6d28d9}.book-row{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.book-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);gap:.85rem;padding:.85rem;display:flex}.book-card img{object-fit:cover;border-radius:8px;flex-shrink:0;width:72px;height:96px}.book-card h4{color:var(--text-heading);margin:0 0 .25rem;font-size:.875rem}.book-card .author{color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem}.tag-row{flex-wrap:wrap;gap:.35rem;display:flex}.tag{background:var(--bg-page);color:var(--text-muted);border-radius:6px;padding:.2rem .45rem;font-size:.65rem}.counselor-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-direction:column;min-height:350px;padding:1.15rem;display:flex;position:relative}.counselor-card .avatar-wrap{background:linear-gradient(135deg, var(--teal-soft), var(--accent-blue-soft));border-radius:16px;width:64px;height:64px;margin-bottom:.85rem;overflow:hidden}.counselor-card .avatar-wrap img{object-fit:cover;width:100%;height:100%}.counselor-card h4{color:var(--text-heading);margin:0 0 .2rem;font-size:1rem}.counselor-card .title{color:var(--text-muted);min-height:2.2rem;margin-bottom:.65rem;font-size:.8rem}.counselor-card .next{color:var(--teal-dark);background:var(--teal-soft);border-radius:8px;margin-top:auto;margin-bottom:.85rem;padding:.4rem .6rem;font-size:.75rem}.bookings-table{border-collapse:collapse;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);width:100%;font-size:.875rem;overflow:hidden}.bookings-table th,.bookings-table td{text-align:left;border-bottom:1px solid var(--border);padding:.85rem 1rem}.bookings-table th{background:var(--bg-page);color:var(--text-heading);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}.bookings-table tr:last-child td{border-bottom:none}.modal-backdrop{z-index:100;background:#0f172a73;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-md);background:#fff;padding:1.5rem}.modal h3{font-family:var(--font-display);margin:0 0 1rem}.modal label{color:var(--text-heading);margin-bottom:.35rem;font-size:.8rem;font-weight:600;display:block}.modal select,.modal input{border:1px solid var(--border);border-radius:8px;width:100%;margin-bottom:.85rem;padding:.5rem .65rem}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:.5rem;display:flex}.game-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);align-items:flex-start;gap:1rem;padding:1.25rem;display:flex}.game-card .emoji{background:linear-gradient(145deg, var(--accent-violet-soft), var(--teal-soft));border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.5rem;display:flex}.game-card h4{color:var(--text-heading);margin:0 0 .35rem;font-size:1rem}.game-card p{color:var(--text-muted);margin:0 0 .65rem;font-size:.85rem}.screening-tools-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;display:grid}.screening-tool-card{flex-direction:column;gap:.8rem;min-height:245px}.screening-tool-card-content{flex-direction:column;flex:1;gap:.2rem;display:flex}.screening-tool-launch-btn{justify-content:center;width:100%;margin-top:auto}.footer-dash{color:var(--text-muted);border-top:1px solid var(--border);justify-content:space-between;margin-top:auto;padding:1rem 1.5rem;font-size:.75rem;display:flex}.header-bar--slim{padding-top:.5rem}.header-pill{text-transform:uppercase;letter-spacing:.1em;color:#047857;text-align:center;background:#10b98114;border:1px solid #10b98166;border-radius:999px;padding:.4rem 1rem;font-size:.78rem;font-weight:600}.header-pill-label{white-space:nowrap;animation:3s ease-in-out quote-fade;display:inline-block}@keyframes quote-fade{0%{opacity:0;transform:translateY(6px)}15%{opacity:1;transform:translateY(0)}85%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}.header-brand-right{align-items:center;gap:.5rem;display:flex}.header-hapminds-text{font-family:var(--font-display);color:#14b8a6;letter-spacing:.08em;font-size:.95rem;font-weight:800}.dash-hero{border-radius:var(--radius-lg);color:#f9fafb;background:#4ec277;margin-bottom:1.75rem;padding:1.9rem 2rem;position:relative;overflow:hidden;box-shadow:0 18px 40px #0f766e59}.dash-hero-inner{justify-content:space-between;align-items:center;gap:2rem;display:flex}.sidebar-character-zone{background:0 0;border:none;border-radius:16px;margin:auto .85rem .7rem;padding:.2rem .25rem .45rem}.sidebar-character-wrap{width:190px;height:265px;margin:0 auto;position:relative}.sidebar-help-cloud{color:#0f172a;text-align:center;z-index:3;background:#fff;border:1px solid #d1d5db;border-radius:20px;max-width:170px;padding:.38rem .7rem;font-size:.78rem;font-weight:700;position:absolute;top:6px;left:50%;transform:translate(-50%);box-shadow:0 8px 18px #0f172a1f}.sidebar-help-cloud:after{content:"";background:#fff;border-bottom:1px solid #d1d5db;border-right:1px solid #d1d5db;width:12px;height:12px;position:absolute;bottom:-7px;left:50%;transform:translate(-50%)rotate(45deg)}.sidebar-character-image{filter:drop-shadow(0 10px 20px #0f172a33);z-index:2;width:auto;height:150px;animation:3s ease-in-out infinite hero-float;position:absolute;top:63%;left:50%;transform:translate(-50%,-50%)}.sidebar-orbit-icon{z-index:1;background:#14b8a61f;border:1px solid #14b8a633;border-radius:999px;justify-content:center;align-items:center;width:30px;height:30px;font-size:.9rem;display:flex;position:absolute}.sidebar-orbit-1{animation:2.8s ease-in-out infinite orbit-bob;top:30%;left:41%}.sidebar-orbit-2{animation:3.2s ease-in-out .5s infinite orbit-bob;top:41%;right:4%}.sidebar-orbit-3{animation:2.6s ease-in-out 1s infinite orbit-bob;top:68%;right:4%}.sidebar-orbit-4{animation:3s ease-in-out 1.5s infinite orbit-bob;bottom:8%;left:41%}.sidebar-orbit-5{animation:3.4s ease-in-out 2s infinite orbit-bob;top:67%;left:4%}.sidebar-orbit-6{animation:2.9s ease-in-out 2.5s infinite orbit-bob;top:41%;left:5%}.dash-hero-copy{max-width:540px}.dash-hero-kicker{text-transform:uppercase;letter-spacing:.16em;opacity:.9;font-size:.75rem;font-weight:600}.dash-hero-heading{font-family:var(--font-display);letter-spacing:.08em;color:#fff;margin:.4rem 0 .25rem;font-size:clamp(1.9rem,3.1vw,2.4rem);font-weight:800}.dash-hero-sub{opacity:.98;margin:0 0 1rem;font-size:.9rem}.dash-hero-score-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(165deg,#fff3 0%,#e0f2fe24 100%);border:1px solid #ffffff4d;border-radius:20px;width:min(360px,100%);padding:1rem 1.05rem;position:relative;overflow:hidden;box-shadow:0 14px 30px #0f172a33}.dash-hero-score-top{text-transform:uppercase;letter-spacing:.12em;color:#ffffffeb;justify-content:space-between;align-items:center;font-size:.74rem;font-weight:700;display:flex}.dash-hero-score-top span:last-child{background:#10b9813d;border:1px solid #a7f3d08c;border-radius:999px;padding:.16rem .46rem}.dash-hero-score-value-row{justify-content:space-between;align-items:flex-end;gap:.75rem;margin-top:.6rem;display:flex}.dash-hero-score-value{font-family:var(--font-display);color:#fff;font-size:clamp(1.7rem,3vw,2.1rem);font-weight:700;line-height:1}.dash-hero-score-value small{opacity:.9;margin-left:.2rem;font-size:.72rem;font-weight:600}.dash-hero-score-badge{color:#ecfeff;background:#3b82f647;border:1px solid #bfdbfe8c;border-radius:999px;padding:.22rem .55rem;font-size:.72rem;font-weight:700}.dash-hero-score-track{background:#ffffff3d;border-radius:999px;width:100%;height:10px;margin-top:.75rem;overflow:hidden}.dash-hero-score-fill{border-radius:inherit;background:linear-gradient(90deg,#99f6e4 0%,#67e8f9 45%,#bfdbfe 100%);height:100%;transition:width .22s;box-shadow:0 0 18px #bae6fdbf}.dash-hero-score-meta{color:#ffffffeb;justify-content:space-between;align-items:center;margin-top:.55rem;font-size:.76rem;font-weight:600;display:flex}.dash-hero-score-meta span:last-child{color:#d9f99d}.dash-hero-score-orb{pointer-events:none;border-radius:999px;position:absolute}.dash-hero-score-orb--one{background:radial-gradient(circle at 30% 30%,#bae6fd80,#7dd3fc14);width:88px;height:88px;animation:3.6s ease-in-out infinite orbit-bob;top:-25px;right:-20px}.dash-hero-score-orb--two{background:radial-gradient(circle at 30% 30%,#a7f3d070,#34d39914);width:58px;height:58px;animation:2.8s ease-in-out .5s infinite orbit-bob;bottom:-20px;right:22px}@media (width<=980px){.dash-hero-inner{flex-direction:column;align-items:flex-start;gap:1rem}.dash-hero-score-card{width:100%;max-width:500px}}.dash-hero-stats{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.dash-hero-stat{background:#0f172a29;border:1px solid #94a3b866;border-radius:16px;min-width:120px;padding:.7rem .9rem}.dash-hero-stat-label{text-transform:uppercase;letter-spacing:.12em;opacity:.85;font-size:.7rem;display:block}.dash-hero-stat-value{margin-top:.25rem;font-size:.98rem;font-weight:700;display:block}.dash-hero-art{pointer-events:none;width:230px;height:230px;position:absolute;bottom:.5rem;right:2.5rem}.dash-hero-character{filter:drop-shadow(0 18px 36px #0f172a40);z-index:2;width:130px;height:auto;animation:3s ease-in-out infinite hero-float,.8s ease-out both hero-entrance;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.dash-hero-orbit-icon{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1;background:#ffffff38;border-radius:999px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.15rem;display:flex;position:absolute;box-shadow:0 4px 14px #0f172a2e}.dash-hero-orbit-1{animation:2.8s ease-in-out infinite orbit-bob;top:6%;left:42%}.dash-hero-orbit-2{animation:3.2s ease-in-out .5s infinite orbit-bob;top:22%;right:2%}.dash-hero-orbit-3{animation:2.6s ease-in-out 1s infinite orbit-bob;top:58%;right:2%}.dash-hero-orbit-4{animation:3s ease-in-out 1.5s infinite orbit-bob;bottom:6%;left:42%}.dash-hero-orbit-5{animation:3.4s ease-in-out 2s infinite orbit-bob;top:56%;left:4%}.dash-hero-orbit-6{animation:2.9s ease-in-out 2.5s infinite orbit-bob;top:18%;left:6%}@keyframes hero-float{0%,to{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 14px))}}@keyframes hero-entrance{0%{opacity:0;transform:translate(-50%,-50%)scale(.85)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}@keyframes orbit-bob{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-8px)scale(1.08)}}.dash-hero-actions{flex-wrap:wrap;gap:.5rem;margin-top:.25rem;display:flex}.dash-overview{margin-bottom:1.75rem}.dash-overview-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.9rem;display:flex}.dash-overview-title{font-family:var(--font-display);color:var(--text-heading);font-size:1.2rem;font-weight:700}.dash-overview-tabs{background:#e5e7eb;border-radius:999px;align-items:center;gap:.15rem;padding:.18rem;display:inline-flex}.dash-overview-tab{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:999px;padding:.3rem .9rem;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.dash-overview-tab.is-active{color:#fff;background:#14b8a6}.dash-overview-row{flex-direction:column;gap:.9rem;display:flex}.dash-banner{color:#3730a3;background:#ede9fe;border-radius:16px;justify-content:space-between;align-items:center;gap:.75rem;padding:.9rem 1.1rem;display:flex;box-shadow:0 6px 18px #4f46e51f}.dash-banner-main{flex-direction:column;gap:.15rem;display:flex}.dash-banner-title{font-size:.95rem;font-weight:700}.dash-banner-sub{color:#4b5563;font-size:.8rem}.dash-banner-dismiss{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.dash-cards-row{scrollbar-width:none;-ms-overflow-style:none;gap:1.05rem;padding-bottom:.35rem;display:flex;overflow-x:auto}.dash-cards-row::-webkit-scrollbar{display:none}.dash-card{cursor:pointer;background:#fff;border-radius:16px;flex-direction:column;flex:none;gap:.45rem;min-width:220px;max-width:270px;min-height:178px;padding:.95rem 1rem;font-size:.93rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 10px 30px #0f172a14}.dash-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #0f172a29}.dash-card:active{transform:translateY(-1px);box-shadow:0 8px 20px #0f172a1f}.dash-card.dash-card--wide{min-width:300px;max-width:340px}.dash-card-main{justify-content:space-between;align-items:center;gap:1rem;display:flex}.dash-card-illustration{object-fit:cover;background:#fee2ff;border-radius:999px;flex-shrink:0;width:76px;height:76px}.dash-card-header{justify-content:space-between;align-items:center;gap:.35rem;display:flex}.dash-card-title{color:var(--text-heading);font-size:1.02rem;font-weight:600}.dash-card-role{color:var(--text-muted);font-size:.82rem}.dash-card-arrow{color:#9ca3af}.dash-card-footer{color:var(--text-muted);justify-content:space-between;align-items:center;margin-top:auto;padding-top:.4rem;font-size:.8rem;display:flex}.dash-card-avatars{align-items:center;display:flex}.dash-card-avatars span{background:#e5e7eb;border:2px solid #fff;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;margin-left:-8px;font-size:.74rem;display:inline-flex}.dash-card-avatars span:first-child{margin-left:0}.dash-card-avatars span.is-count{color:#fff;background:#4f46e5}.dash-card--purple{background:linear-gradient(145deg,#f5f3ff 0%,#ede9fe 100%);border:1px solid #ddd6fe;box-shadow:0 8px 24px #8b5cf626}.dash-card--purple:hover{box-shadow:0 18px 44px #8b5cf640}.dash-card--mint{background:linear-gradient(145deg,#ecfdf5 0%,#d1fae5 100%);border:1px solid #a7f3d0;box-shadow:0 8px 24px #10b98126}.dash-card--mint:hover{box-shadow:0 18px 44px #10b98140}.dash-card--peach{background:linear-gradient(145deg,#fff7ed 0%,#ffedd5 100%);border:1px solid #fed7aa;box-shadow:0 8px 24px #f9731626}.dash-card--peach:hover{box-shadow:0 18px 44px #f9731640}.dash-card--sky{background:linear-gradient(145deg,#e0f2fe 0%,#bae6fd 100%);border:1px solid #7dd3fc;box-shadow:0 8px 24px #0ea5e926}.dash-card--sky:hover{box-shadow:0 18px 44px #0ea5e940}.dash-card--rose{background:linear-gradient(145deg,#fff1f2 0%,#fecdd3 100%);border:1px solid #fda4af;box-shadow:0 8px 24px #f43f5e26}.dash-card--rose:hover{box-shadow:0 18px 44px #f43f5e40}.dash-card--lavender{background:linear-gradient(145deg,#ede9fe 0%,#ddd6fe 100%);border:1px solid #c4b5fd;box-shadow:0 8px 24px #7c3aed26}.dash-card--lavender:hover{box-shadow:0 18px 44px #7c3aed40}.dash-category-tabs{flex-wrap:wrap;gap:.4rem;margin-bottom:1rem;display:flex}.dash-category-tab{border:1px solid var(--border);color:#64748b;cursor:pointer;background:#fff;border-radius:999px;padding:.45rem 1rem;font-size:.82rem;font-weight:600;transition:background .15s,color .15s,border-color .15s,box-shadow .15s}.dash-category-tab:hover{color:#334155;background:#f1f5f9}.dash-category-tab.is-active{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0ea5e9 100%);border-color:#0000;box-shadow:0 4px 14px #14b8a64d}.dash-workshops-section{margin:0 0 1.1rem}.dash-workshops-head{justify-content:space-between;align-items:center;margin-bottom:.7rem;display:flex}.dash-workshops-head h3{color:var(--text-heading);margin:0;font-size:1rem}.dash-workshops-head span{letter-spacing:.08em;text-transform:uppercase;color:#64748b;font-size:.75rem;font-weight:700}.dash-workshops-layout{grid-template-columns:minmax(260px,.95fr) minmax(0,1.35fr);gap:.9rem;display:grid}.dash-workshops-calendar-card,.dash-workshops-list-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:.85rem .95rem;box-shadow:0 10px 26px #0f172a12}.dash-workshops-calendar-title{justify-content:space-between;margin-bottom:.5rem;display:flex}.dash-workshops-calendar-title strong{font-size:.84rem}.dash-workshops-calendar-title small{color:#64748b;font-size:.7rem}.dash-workshops-weekdays,.dash-workshops-days{grid-template-columns:repeat(7,minmax(0,1fr));gap:.3rem;display:grid}.dash-workshops-weekdays span{text-align:center;color:#64748b;font-size:.65rem;font-weight:700}.dash-workshops-day{color:#334155;background:#f8fafc;border-radius:8px;justify-content:center;align-items:center;height:28px;font-size:.75rem;display:inline-flex}.dash-workshops-day.is-event{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0ea5e9 100%);font-weight:700}.dash-workshops-list{gap:.55rem;display:grid}.dash-workshop-mode{white-space:nowrap;color:#1d4ed8;background:#dbeafe;border-radius:999px;align-items:center;padding:.22rem .5rem;font-size:.68rem;font-weight:700;display:inline-flex}.dash-workshops{margin-bottom:1.1rem}.dash-workshops-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.dash-workshops-header h3{color:var(--text-heading);margin:0;font-size:1rem}.dash-workshops-header span{color:#64748b;text-transform:uppercase;letter-spacing:.08em;font-size:.76rem;font-weight:700}.dash-workshops-grid{grid-template-columns:minmax(260px,.95fr) minmax(0,1.35fr);gap:.9rem;display:grid}.dash-workshop-calendar-card,.dash-workshop-list-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:.85rem .95rem;box-shadow:0 10px 26px #0f172a12}.dash-workshop-calendar-head{justify-content:space-between;align-items:center;margin-bottom:.55rem;display:flex}.dash-workshop-calendar-head strong{font-size:.85rem}.dash-workshop-calendar-head span{color:#64748b;font-size:.72rem}.dash-workshop-weekdays,.dash-workshop-days{grid-template-columns:repeat(7,minmax(0,1fr));gap:.3rem;display:grid}.dash-workshop-weekdays span{text-align:center;color:#64748b;letter-spacing:.04em;font-size:.66rem;font-weight:700}.dash-workshop-day{color:#334155;background:#f8fafc;border-radius:8px;justify-content:center;align-items:center;height:28px;font-size:.76rem;display:inline-flex}.dash-workshop-day.is-workshop{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0ea5e9 100%);font-weight:700;box-shadow:0 8px 14px #0ea5e93d}.dash-workshop-list{gap:.6rem;display:grid}.dash-workshop-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;justify-content:space-between;align-items:center;gap:.65rem;padding:.58rem .66rem;display:flex}.dash-workshop-item strong{color:#1f2937;font-size:.84rem;display:block}.dash-workshop-item span{color:#64748b;font-size:.74rem;display:block}.dash-workshop-mode{color:#0f172a;white-space:nowrap;background:#dbeafe;border-radius:999px;align-items:center;padding:.25rem .52rem;font-size:.68rem;font-weight:700;display:inline-flex}.dash-workshop-mode.mode-online{color:#5b21b6;background:#ddd6fe}.dash-workshop-mode.mode-on-campus{color:#0f766e;background:#ccfbf1}.dash-workshop-mode.mode-hybrid{color:#92400e;background:#fef3c7}.dash-card-icon-wrap{background:#ffffffb3;border-radius:12px;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:.58rem;display:flex;box-shadow:0 4px 12px #0f172a14}.dash-card-icon-img{object-fit:contain;width:32px;height:32px}.dash-screening-modal{max-width:740px;max-height:min(88vh,780px);overflow-y:auto}.dash-screening-modal-subtitle{letter-spacing:.04em;text-transform:uppercase;color:#0f766e;margin:0 0 .75rem;font-size:.82rem;font-weight:700}.dash-screening-modal-list{color:#374151;gap:.45rem;margin:.75rem 0 0;padding-left:1.05rem;font-size:.92rem;display:grid}.dash-screening-question-card{background:linear-gradient(#f9fafb 0%,#f3f6fb 100%);border:1px solid #d1d5db;border-radius:16px;padding:1rem 1.05rem;box-shadow:0 10px 24px #0f172a14}.dash-screening-questions{gap:.8rem;display:grid}.dash-screening-question-card--animate{animation:.26s screeningSlideIn}@keyframes screeningSlideIn{0%{opacity:0;transform:translateY(10px)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}.dash-screening-question-text{color:#1f2937;margin:0 0 .8rem;font-size:1.02rem;font-weight:600}.dash-screening-options{flex-wrap:wrap;gap:.65rem;display:flex}.dash-screening-option{color:#334155;background:#fff;border:1px solid #cbd5e1;border-radius:999px;align-items:center;gap:.45rem;padding:.5rem .85rem;font-size:.86rem;font-weight:600;transition:transform .15s,box-shadow .15s,border-color .15s,background .15s;display:inline-flex}.dash-screening-option:hover{border-color:#67e8f9;transform:translateY(-1px);box-shadow:0 8px 20px #06b6d424}.dash-screening-option input{margin:0}.dash-screening-option.is-selected{color:#0f172a;background:linear-gradient(135deg,#ccfbf1 0%,#dbeafe 100%);border-color:#14b8a6}.dash-screening-result{border-radius:14px;padding:.85rem 1rem}.dash-screening-result.is-typical{background:#ecfdf5;border:1px solid #a7f3d0}.dash-screening-result.is-flagged{background:#fff7ed;border:1px solid #fdba74}.dash-screening-result-title{color:#111827;margin:0;font-size:.95rem;font-weight:700}.dash-screening-result-score{color:#0f766e;margin:.3rem 0 .65rem;font-size:.85rem;font-weight:700}.dash-screening-reco-title{text-transform:uppercase;color:#0f766e;margin:.75rem 0 0;font-size:.84rem;font-weight:700}.modal-actions .btn-primary:disabled{opacity:.55;cursor:not-allowed}.dash-screening-progress-wrap{margin-bottom:.85rem}.dash-screening-progress-text{color:#475569;justify-content:space-between;align-items:center;margin-bottom:.35rem;font-size:.78rem;font-weight:600;display:flex}.dash-screening-progress-track{background:#e2e8f0;border-radius:999px;width:100%;height:8px;overflow:hidden}.dash-screening-progress-fill{border-radius:inherit;background:linear-gradient(90deg,#14b8a6 0%,#0ea5e9 100%);height:100%;transition:width .25s}.dash-screening-step-dots{gap:.4rem;margin-top:.5rem;display:flex}.dash-screening-step-dot{background:#cbd5e1;border-radius:999px;width:7px;height:7px;transition:transform .2s,background .2s}.dash-screening-step-dot.is-active{background:#14b8a6;transform:scale(1.2)}.dash-screening-hint{color:#64748b;margin-top:.35rem;font-size:.76rem}.dash-metrics{margin-bottom:1.75rem}.dash-metrics-grid{grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) minmax(0,1.1fr);gap:1rem;display:grid}.dash-metric-card{background:#f9fafb;border-radius:22px;padding:1.1rem 1.25rem;box-shadow:0 12px 32px #0f172a14}.dash-metric-header{justify-content:space-between;align-items:center;margin-bottom:.6rem;font-size:.8rem;display:flex}.dash-metric-title{color:var(--text-heading);font-weight:700}.dash-metric-sub{color:var(--text-muted);font-size:.78rem}.dash-metric-chip{color:#0369a1;background:#e0f2fe;border-radius:999px;padding:.2rem .6rem;font-size:.7rem;font-weight:600}.dash-metric-body{background:#fee2e2;border-radius:20px;flex-direction:column;gap:.35rem;padding:.9rem 1rem;display:flex}.dash-metric-main-value{align-items:baseline;gap:.35rem;font-weight:700;display:flex}.dash-metric-main-value span:first-child{font-size:1.1rem}.dash-metric-main-value span:last-child{color:#16a34a;font-size:.75rem}.dash-metric-note{color:#4b5563;font-size:.75rem}.dash-metric-small-list{grid-template-columns:1fr;gap:.6rem;display:grid}.dash-metric-small{background:#fdf2ff;border-radius:18px;padding:.8rem .9rem}.dash-metric-small+.dash-metric-small{background:#eff6ff}.dash-metric-small-title{justify-content:space-between;align-items:center;margin-bottom:.2rem;font-size:.8rem;display:flex}.dash-metric-small-label{font-weight:600}.dash-metric-small-value{font-weight:700}.dash-metric-small-note{color:#6b7280;font-size:.7rem}.dash-metric-timeline,.dash-metric-issues{flex-direction:column;gap:.75rem;font-size:.78rem;display:flex}.dash-timeline-row,.dash-issue-row{gap:.6rem;display:flex}.dash-timeline-time{color:#9ca3af;width:60px}.dash-timeline-dot{background:#f97316;border-radius:999px;width:10px;height:10px;margin-top:.2rem}.dash-timeline-text span{display:block}.dash-issue-row{align-items:center}.dash-issue-main{flex:1}.dash-issue-title{font-weight:500}.dash-issue-meta{color:#9ca3af;font-size:.7rem}.dash-issue-tag{color:#16a34a;background:#dcfce7;border-radius:999px;padding:.18rem .55rem;font-size:.7rem;font-weight:600}.dash-issue-tag.is-update{color:#2563eb;background:#dbeafe}.dash-issue-tag.is-report{color:#b91c1c;background:#fee2e2}.dash-issue-tag.is-control{color:#b45309;background:#fef3c7}.dash-issue-tag.is-meeting{color:#7c3aed;background:#ede9fe}@media (width<=960px){.dash-metrics-grid,.dash-workshops-grid,.dash-workshops-layout{grid-template-columns:minmax(0,1fr)}}.dash-hero-inner{width:100%;max-width:1120px}.dash-product-label{text-transform:uppercase;letter-spacing:.12em;color:var(--teal-dark);font-size:.65rem;font-weight:700}.dash-product-title{font-family:var(--font-display);letter-spacing:-.03em;color:var(--text-heading);background:linear-gradient(135deg,#0f766e 0%,#4f46e5 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:.35rem 0 .75rem;font-size:clamp(2rem,4vw,2.75rem);font-weight:700}.dash-product-desc{color:var(--text);margin:0 0 1.25rem;font-size:.95rem;line-height:1.55}.dash-hero-actions{flex-wrap:wrap;gap:.65rem;display:flex}.features-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;display:grid}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1.15rem 1.1rem;transition:box-shadow .2s,transform .15s}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-card .feature-icon{margin-bottom:.5rem;font-size:1.5rem;display:block}.feature-card h4{color:var(--text-heading);margin:0 0 .4rem;font-size:.95rem}.feature-card p{color:var(--text-muted);margin:0;font-size:.8rem;line-height:1.45}.counselor-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.counselor-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-wrap:wrap;align-items:center;gap:1rem;padding:1rem 1.15rem;display:flex}.counselor-row-avatar{background:var(--teal-soft);border-radius:14px;flex-shrink:0;width:56px;height:56px;overflow:hidden}.counselor-row-avatar img{object-fit:cover;width:100%;height:100%}.counselor-row-info{flex:1;min-width:180px}.counselor-row-info strong{color:var(--text-heading);font-size:1rem;display:block}.counselor-row-title{color:var(--text-muted);font-size:.8rem}.counselor-row-slot{flex-direction:column;gap:.15rem;min-width:140px;display:flex}.next-slot-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.65rem;font-weight:600}.next-slot-value{color:var(--teal-dark);font-size:.8rem;font-weight:600}.counselor-book-btn{flex-shrink:0;margin-left:auto}.quick-links{flex-wrap:wrap;gap:.5rem;display:flex}.quick-link{border:1px solid var(--border);color:var(--text-heading);background:#fff;border-radius:10px;padding:.55rem 1rem;font-size:.85rem;font-weight:600}.quick-link:hover{background:var(--teal-soft);color:var(--teal-dark);border-color:#0000}.ai-bot-screen{grid-template-columns:230px minmax(0,1fr);align-items:stretch;gap:1rem;display:grid}.ai-bot-sidebar{border:1px solid var(--border);background:#f8fafc;border-radius:16px;padding:1rem}.ai-bot-sidebar h3{margin:0 0 .75rem;font-size:.92rem}.ai-bot-sidebar-list{color:#475569;gap:.45rem;margin:0;padding-left:1rem;font-size:.82rem;display:grid}.ai-bot-school-chip{color:#065f46;background:#d1fae5;border-radius:999px;align-items:center;margin-top:1rem;padding:.35rem .65rem;font-size:.76rem;font-weight:700;display:inline-flex}.ai-bot-main{border:1px solid var(--border);background:#fff;border-radius:16px;flex-direction:column;gap:.85rem;padding:1rem;display:flex}.ai-bot-chat-header{justify-content:space-between;align-items:center;font-size:.84rem;display:flex}.ai-bot-chat-header span{color:#0f766e;font-weight:700}.ai-bot-chat-feed{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;gap:.55rem;padding:.8rem;display:grid}.ai-bot-msg{border-radius:12px;max-width:85%;padding:.55rem .7rem;font-size:.82rem;line-height:1.45}.ai-bot-msg--bot{color:#164e63;background:#ecfeff;border:1px solid #a5f3fc}.ai-bot-msg--user{color:#14532d;background:#dcfce7;border:1px solid #86efac;margin-left:auto}.ai-bot-prompts{flex-wrap:wrap;gap:.45rem;display:flex}.ai-bot-prompt-btn{color:#334155;background:#fff;border:1px solid #cbd5e1;border-radius:999px;padding:.35rem .68rem;font-size:.76rem;font-weight:600}.ai-bot-input-row{gap:.6rem;display:flex}.ai-bot-input-row input{border:1px solid #cbd5e1;border-radius:10px;flex:1;padding:.6rem .75rem;font-size:.85rem}@media (width<=600px){.counselor-row .counselor-book-btn{justify-content:center;width:100%;margin-left:0}}@media (width<=900px){.dashboard{flex-direction:column}.sidebar{display:none}.main-wrap{width:100%;min-height:auto;max-height:none;margin-left:0;overflow:visible}.main-scroll{flex:none;overflow:visible}.main-sticky-bar{border-bottom:none;padding-top:.5rem}.header-bar{flex-wrap:wrap;margin:.75rem}.header-actions-icons{border-right:none;margin-right:0;padding-right:0}.header-actions{flex-wrap:wrap;justify-content:space-between;gap:.75rem;width:100%}.header-hapminds{margin-left:auto}.content-area{padding:0 .85rem 5.8rem}.mobile-bottom-nav{z-index:250;padding:.5rem .35rem calc(.5rem + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(10px);background:#fffffff5;border-top:1px solid #dbe4ea;grid-template-columns:repeat(5,minmax(0,1fr));gap:0;display:grid;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -10px 26px #0f172a1f}.mobile-bottom-nav-item{color:#64748b;text-align:center;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:.18rem;padding:.42rem .2rem;font-size:.64rem;font-weight:600;text-decoration:none;display:inline-flex}.mobile-bottom-nav-item svg{stroke-width:2.1px;width:18px;height:18px}.mobile-bottom-nav-item.active{color:#0f766e;background:#e6f7f4}.counselor-chat-fab{bottom:5.7rem;right:.9rem}.counselor-chat-panel{width:min(380px,100vw - 1.1rem);height:min(560px,100vh - 7rem);bottom:5.35rem;right:.55rem}}.resources-page{max-width:1120px;margin:0 1.5rem 2rem .25rem;padding-bottom:2rem}.resources-header{margin-bottom:1.25rem}.resources-title{font-family:var(--font-display);color:var(--text-heading);letter-spacing:-.02em;margin:0 0 .35rem;font-size:1.9rem;font-weight:700}.resources-subtitle{color:var(--text-muted);margin:0;font-size:.95rem}.resources-featured-wrap{margin-bottom:2rem}.resources-featured{background-position:100%;background-size:cover;border-radius:20px;min-height:320px;position:relative;overflow:hidden;box-shadow:0 16px 40px #5b21b633}.resources-featured-bg{pointer-events:none;background:radial-gradient(circle at 10% 0,#81e6d973 0,#0000 40%),radial-gradient(circle at 80% 10%,#e0e7ff80 0,#0000 42%),linear-gradient(105deg,#4c1d95bf 0%,#7c3aeda6 40%,#22c55e99 100%);position:absolute;inset:0}.resources-featured-inner{grid-template-columns:1fr;align-items:center;gap:1rem;min-height:320px;padding:2.4rem 2rem 2.4rem 2.25rem;display:grid;position:relative}@media (width<=640px){.resources-featured-inner{grid-template-columns:1fr}}.resources-featured-copy{color:#fff;z-index:1}.resources-featured-badge{color:#fff;letter-spacing:.06em;background:#22c55e;border-radius:8px;margin-bottom:.75rem;padding:.35rem .65rem;font-size:.65rem;font-weight:800;display:inline-block}.resources-featured-title{max-width:22em;margin:0 0 .5rem;font-size:clamp(1.4rem,2.7vw,1.75rem);font-weight:700;line-height:1.25}.resources-featured-desc{opacity:.95;max-width:28em;margin:0 0 .5rem;font-size:.95rem;line-height:1.5}.resources-featured-tag{opacity:.85;margin-bottom:1rem;font-size:.7rem;display:block}.resources-watch-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.55rem 1.15rem;font-size:.875rem;font-weight:700;display:inline-flex}.resources-watch-btn:hover{filter:brightness(1.08)}.resources-play-icon{background:#ffffff40;border-radius:6px;justify-content:center;align-items:center;width:22px;height:22px;font-size:.65rem;display:flex}.resources-carousel-dots{justify-content:center;align-items:center;gap:.5rem;margin-top:.85rem;display:flex}.resources-dot{cursor:pointer;background:#cbd5e1;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:width .2s,border-radius .2s,background .2s}.resources-dot.active{background:#fff;border-radius:4px;width:28px;box-shadow:0 0 0 2px #e2e8f0}.resources-categories-section{margin-bottom:1.5rem}.resources-section-label{letter-spacing:.04em;text-transform:uppercase;color:var(--text-heading);margin:0 0 .85rem;font-size:.85rem;font-weight:800}.resources-categories{flex-wrap:wrap;gap:.65rem;display:flex}.resources-cat-card{cursor:pointer;color:#64748b;background:radial-gradient(circle at 0 0,#e0f2fe 0,#f9fafb 45%);border:2px solid #eef0f4;border-radius:16px;flex-direction:column;flex:1;align-items:center;gap:.5rem;min-width:120px;max-width:170px;padding:1rem .65rem;transition:border-color .15s,background .15s,color .15s;display:flex}.resources-cat-card:hover{color:#475569;border-color:#cbd5e1}.resources-cat-card.active{color:#15803d;background:radial-gradient(circle at 0 0,#bbf7d0 0,#0000 40%),linear-gradient(#ecfdf5 0%,#d1fae5 100%);border-color:#22c55e}.resources-cat-card.active .resources-cat-icon{color:#fff;background:#22c55e}.resources-cat-icon{width:48px;height:48px;color:inherit;background:linear-gradient(145deg,#fff 0%,#eff6ff 50%,#e0f2fe 100%);border-radius:14px;justify-content:center;align-items:center;display:flex;box-shadow:0 2px 8px #0000000a}.resources-cat-icon svg{stroke-linecap:round;stroke-linejoin:round}.resources-cat-icon--health svg{color:#22c55e}.resources-cat-icon--meditation svg{color:#6366f1}.resources-cat-icon--selfcare svg{color:#ec4899}.resources-cat-icon--mindfulness svg{color:#0ea5e9}.resources-cat-icon--selfgrowth svg{color:#f97316}.resources-cat-icon--games svg{color:#a855f7}.resources-cat-label{text-align:center;color:var(--text-heading);font-size:.8rem;font-weight:700;line-height:1.25}.resources-cat-card.active .resources-cat-label{color:#166534}.resources-toolbar{margin-bottom:1.5rem}.resources-search{color:#94a3b8;background:#fff;border:1px solid #e8ecf0;border-radius:14px;align-items:center;gap:.65rem;margin-bottom:.85rem;padding:.65rem 1rem;display:flex}.resources-search input{color:var(--text-heading);background:0 0;border:none;outline:none;flex:1;font-size:.9rem}.resources-search input::placeholder{color:#94a3b8}.resources-type-filters{flex-wrap:wrap;gap:.45rem;display:flex}.resources-type-filters button{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:10px;padding:.45rem .85rem;font-size:.8rem;font-weight:600}.resources-type-filters button:hover{color:#475569;background:#e2e8f0}.resources-type-filters button.active{color:#fff;background:linear-gradient(135deg,#22c55e 0%,#0ea5e9 50%,#6366f1 100%)}.resources-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.resources-item-card{background:#fff;border:1px solid #eef0f4;border-radius:16px;transition:box-shadow .2s;overflow:hidden;box-shadow:0 2px 8px #0000000a}.resources-item-card:hover{box-shadow:0 14px 30px #1e40af29}.resources-item-media{aspect-ratio:16/10;background:radial-gradient(circle at 0 0,#e0f2fe 0,#f9fafb 45%);position:relative}.resources-item-media img{object-fit:cover;width:100%;height:100%}.resources-item-play{color:#fff;opacity:0;background:#00000040;justify-content:center;align-items:center;font-size:1.25rem;transition:opacity .2s;display:flex;position:absolute;inset:0}.resources-item-card:hover .resources-item-play{opacity:1}.resources-item-fallback{justify-content:center;align-items:center;min-height:100px;font-size:2rem;display:flex}.resources-item-fallback.resources-type-article{background:linear-gradient(135deg,#f9fafb 0%,#e0f2fe 100%)}.resources-item-fallback.resources-type-audio{background:linear-gradient(135deg,#eef2ff 0%,#e0f2fe 100%)}.resources-item-fallback.resources-type-game{background:linear-gradient(135deg,#ecfdf5 0%,#fef9c3 100%)}.resources-item-body{padding:1rem 1.15rem 1.15rem}.resources-item-type{text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;font-size:.65rem;font-weight:700}.resources-item-body h4{color:var(--text-heading);margin:.25rem 0 .35rem;font-size:.98rem;font-weight:700;line-height:1.3}.resources-item-meta{color:var(--text-muted);margin:0;font-size:.75rem}.resources-item-focus{color:#047857;background:#ecfdf5;border-radius:6px;margin-top:.4rem;padding:.15rem .45rem;font-size:.65rem;font-weight:600;display:inline-block}.resources-empty{text-align:center;color:var(--text-muted);padding:2rem;font-size:.9rem}.resources-item-card{cursor:pointer}.res-watch-page{flex-direction:column;height:100%;display:flex}.res-watch-topbar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;padding:.75rem 0;display:flex}.res-watch-back{color:#0f766e;cursor:pointer;white-space:nowrap;background:0 0;border:none;font-size:.85rem;font-weight:600}.res-watch-back:hover{text-decoration:underline}.res-watch-topbar-title{font-family:var(--font-display);color:var(--text-heading);text-align:center;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;margin:0;font-size:1rem;font-weight:700;overflow:hidden}.res-watch-topbar-actions{flex-shrink:0;gap:.5rem;display:flex}.res-watch-topbar-actions .icon-btn{border-radius:10px;width:auto;height:auto;padding:.35rem .75rem;font-size:.78rem}.res-watch-layout{flex:1;grid-template-columns:1fr 300px;gap:1.25rem;min-height:0;display:grid}.res-watch-main{min-width:0}.res-watch-player{aspect-ratio:16/9;background:#0f172a;border-radius:16px;width:100%;margin-bottom:1rem;overflow:hidden}.res-watch-player iframe{border:none;width:100%;height:100%}.res-watch-fallback-img{object-fit:cover;width:100%;height:100%}.res-watch-fallback{color:#94a3b8;justify-content:center;align-items:center;width:100%;height:100%;font-size:.9rem;display:flex}.res-watch-info{padding-bottom:1.5rem}.res-watch-desc{color:var(--text);margin:0 0 .75rem;font-size:.88rem;line-height:1.55}.res-watch-contributor{color:var(--text-muted);margin-bottom:.75rem;font-size:.82rem}.res-watch-tags{flex-wrap:wrap;gap:.35rem;display:flex}.res-detail-tag{border:1px solid var(--border);color:#64748b;background:#f8fafc;border-radius:999px;padding:.25rem .6rem;font-size:.75rem}.res-watch-sidebar{border:1px solid var(--border);background:#f9fafb;border-radius:16px;flex-direction:column;gap:.75rem;max-height:520px;padding:1rem;display:flex;overflow-y:auto}.res-watch-notes-header{color:var(--text-heading);align-items:center;gap:.35rem;font-size:.9rem;font-weight:700;display:flex}.res-watch-notes-count{color:var(--text-muted);font-size:.82rem;font-weight:400}.res-watch-notes-input textarea{border:1px solid var(--border);resize:vertical;width:100%;min-height:60px;color:var(--text);background:#fff;border-radius:10px;padding:.6rem .75rem;font-family:inherit;font-size:.82rem}.res-watch-notes-input textarea::placeholder{color:#94a3b8}.res-watch-add-note{color:#fff;cursor:pointer;background:linear-gradient(135deg,#22c55e,#14b8a6);border:none;border-radius:10px;width:100%;margin-top:.5rem;padding:.55rem;font-size:.82rem;font-weight:700;transition:filter .15s;display:block}.res-watch-add-note:hover{filter:brightness(1.08)}.res-watch-notes-empty{text-align:center;color:var(--text-muted);padding:1.5rem .5rem}.res-watch-notes-empty span{margin-bottom:.5rem;font-size:2rem;display:block}.res-watch-notes-empty strong{color:var(--text-heading);margin-bottom:.25rem;font-size:.88rem;display:block}.res-watch-notes-empty p{margin:0;font-size:.78rem}.res-watch-note-item{border:1px solid var(--border);color:var(--text);background:#fff;border-radius:10px;padding:.6rem .75rem;font-size:.82rem;line-height:1.45}@media (width<=768px){.res-watch-layout{grid-template-columns:1fr}}.book-modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.book-modal{background:#fff;border-radius:20px;flex-direction:column;width:100%;max-width:720px;max-height:calc(100vh - 2rem);display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.book-modal-header{border-bottom:1px solid #eef0f4;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.book-modal-header h2{color:#1a1f2e;font-size:1.25rem;font-weight:700;font-family:var(--font-display,Georgia, serif);margin:0}.book-modal-close{color:#64748b;cursor:pointer;background:#f4f6f8;border:none;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.book-modal-close:hover{color:#1e293b;background:#e8ecf0}.book-modal-consultant{border-bottom:1px solid #eef0f4;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.book-modal-avatar{object-fit:cover;background:linear-gradient(145deg,#e0f2f1,#e0e7ff);border-radius:14px;width:56px;height:56px}.book-modal-name{color:#1a1f2e;font-size:1.05rem;font-weight:700}.book-modal-rating{color:#475569;align-items:center;gap:.25rem;margin-top:.2rem;font-size:.9rem;font-weight:600;display:flex}.book-modal-star{color:#eab308;font-size:1rem}.book-modal-body{flex:1;grid-template-columns:1fr 1fr;gap:0;min-height:0;display:grid;overflow-y:auto}@media (width<=640px){.book-modal-body{grid-template-columns:1fr}}.book-modal-cal{border-right:1px solid #eef0f4;padding:1.25rem 1.25rem 1.5rem}@media (width<=640px){.book-modal-cal{border-bottom:1px solid #eef0f4;border-right:none}}.book-modal-month{color:#334155;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.95rem;font-weight:600;display:flex}.book-modal-nav-arrow{color:#475569;cursor:pointer;background:#f1f5f9;border:none;border-radius:10px;width:36px;height:36px;font-size:1.25rem;line-height:1}.book-modal-nav-arrow:hover{background:#e2e8f0}.book-modal-weekdays{color:#94a3b8;text-align:center;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.5rem;font-size:.7rem;font-weight:600;display:grid}.book-modal-days{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.book-modal-day-empty{min-height:36px}.book-modal-day{color:#334155;cursor:pointer;background:0 0;border:none;border-radius:50%;min-height:36px;font-size:.8rem;font-weight:500}.book-modal-day:hover:not(.book-modal-day-empty){background:#f1f5f9}.book-modal-day.selected{color:#fff;background:linear-gradient(135deg,#c4b5fd 0%,#a78bfa 100%);font-weight:700}.book-modal-time{padding:1.25rem 1.25rem 1.5rem}.book-modal-time-title{color:#1a1f2e;margin:0 0 .75rem;font-size:.95rem;font-weight:700}.book-modal-time-toggle{gap:.5rem;margin-bottom:1rem;display:flex}.book-modal-time-toggle button{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:10px;flex:1;padding:.5rem .65rem;font-size:.8rem;font-weight:600}.book-modal-time-toggle button.muted{color:#64748b;background:#f1f5f9}.book-modal-time-toggle button.active-gradient{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#6366f1 100%)}.book-modal-quick-slots{flex-wrap:wrap;gap:.4rem;margin-bottom:1rem;display:flex}.book-modal-quick-btn{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.35rem .65rem;font-size:.75rem;font-weight:600}.book-modal-quick-btn:hover{color:#6366f1;border-color:#a78bfa}.book-modal-time-display{color:#1e293b;text-align:center;letter-spacing:-.02em;margin-bottom:.75rem;font-size:1.75rem;font-weight:800}.book-modal-clock-wrap{justify-content:center;margin-bottom:1rem;display:flex}.book-modal-clock{aspect-ratio:1;background:linear-gradient(#f8fafc 0%,#f1f5f9 100%);border:1px solid #e2e8f0;border-radius:50%;flex-shrink:0;width:200px;height:200px;position:relative}.book-modal-clock-center{z-index:1;pointer-events:none;background:#94a3b8;border-radius:50%;width:8px;height:8px;margin:0;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.book-modal-clock-num{color:#475569;cursor:pointer;box-sizing:border-box;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;margin:0;padding:0;font-size:.8rem;font-weight:600;line-height:1;display:flex;position:absolute}.book-modal-clock-num:hover{background:#e2e8f0}.book-modal-clock-num.selected{color:#fff;z-index:2;background:linear-gradient(135deg,#8b5cf6 0%,#6366f1 100%);font-weight:700;box-shadow:0 2px 8px #6366f173}.book-modal-minutes-label{color:#64748b;margin-bottom:.4rem;font-size:.7rem;font-weight:600}.book-modal-minutes{flex-wrap:wrap;gap:.35rem;margin-bottom:.75rem;display:flex}.book-modal-min-chip{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:50%;width:32px;height:32px;padding:0;font-size:.65rem;font-weight:600}.book-modal-min-chip:hover{background:#e2e8f0}.book-modal-min-chip.selected{color:#fff;background:linear-gradient(135deg,#8b5cf6 0%,#6366f1 100%)}.book-modal-ampm{gap:.5rem;margin-bottom:1rem;display:flex}.book-modal-ampm button{cursor:pointer;color:#94a3b8;background:#f1f5f9;border:none;border-radius:8px;flex:1;padding:.45rem;font-size:.85rem;font-weight:600}.book-modal-ampm button.selected{color:#1d4ed8;background:#dbeafe}.book-modal-session-label{color:#64748b;margin-bottom:.35rem;font-size:.7rem;font-weight:600;display:block}.book-modal-select{border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:.5rem .65rem;font-size:.85rem}.book-modal-footer{background:#fafbfc;border-top:1px solid #eef0f4;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem 1.25rem;display:flex}.book-modal-cancel{cursor:pointer;color:#475569;background:#f1f5f9;border:none;border-radius:12px;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600}.book-modal-cancel:hover{background:#e2e8f0}.book-modal-confirm{cursor:pointer;color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#6366f1 100%);border:none;border-radius:12px;padding:.65rem 1.5rem;font-size:.9rem;font-weight:600}.book-modal-confirm:hover{filter:brightness(1.05)}
