.pd-hub{flex-direction:column;min-height:100vh;display:flex}.pd-hub-banner{border:2px solid var(--ls-accent,#f97316);background:linear-gradient(135deg,#fff7ed,#fde68a);border-radius:14px;grid-template-columns:1fr auto;align-items:center;gap:16px;width:calc(100% - 40px);max-width:1100px;margin:0 auto 16px;padding:14px 20px;display:grid}.pd-hub-banner-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--ls-accent-deep,#ea580c);margin-bottom:4px;font-size:12px;font-weight:800;display:block}.pd-hub-banner>div>span:last-child{color:#1f2937;font-weight:600}.pd-hub-hero{grid-template-columns:1fr auto;align-items:end;gap:24px;max-width:1100px;margin:16px auto 36px;padding:0 clamp(20px,4vw,40px);display:grid}@media (max-width:760px){.pd-hub-hero{grid-template-columns:1fr;align-items:start}}.pd-hub-hero-copy h1{letter-spacing:-.02em;margin:8px 0 6px;font-size:clamp(28px,4.4vw,44px);font-weight:900}.pd-hub-hero-copy p{color:var(--ls-muted,#4b5563);max-width:560px;margin:0;font-size:15.5px;line-height:1.5}.pd-hub-stats{flex-wrap:wrap;gap:12px;display:flex}.pd-hub-stat{text-align:center;background:#fff;border:1px solid #1f293714;border-radius:14px;min-width:92px;padding:12px 18px;box-shadow:0 8px 18px -16px #1f293733}.pd-hub-stat-value{color:#1f2937;font-size:22px;font-weight:900;display:block}.pd-hub-stat-label{color:var(--ls-muted,#4b5563);margin-top:2px;font-size:12px;display:block}.pd-hub-stat[data-attention=true]{border-color:var(--ls-accent,#f97316);background:linear-gradient(135deg,#fff7ed,#fed7aa)}.pd-hub-stat[data-attention=true] .pd-hub-stat-value{color:var(--ls-accent-deep,#ea580c)}.pd-hub-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;width:100%;max-width:1100px;margin:0 auto;padding:0 clamp(20px,4vw,40px) 56px;display:grid}.pd-hub-card{color:inherit;background:#fff;border:2px solid #1f293714;border-radius:18px;grid-template-columns:48px 1fr auto;align-items:start;gap:14px;padding:22px 24px;text-decoration:none;transition:transform .15s,box-shadow .15s,border-color .15s;display:grid;position:relative;box-shadow:0 14px 30px -22px #1f293740}.pd-hub-card:hover{border-color:var(--ls-accent,#f97316);transform:translateY(-3px);box-shadow:0 22px 40px -22px #f9731673}.pd-hub-card-icon{font-size:32px;line-height:1}.pd-hub-card h3{color:#1f2937;margin:0 0 4px;font-size:18px;font-weight:800}.pd-hub-card p{color:var(--ls-muted,#4b5563);margin:0;font-size:14.5px;line-height:1.45}.pd-hub-card-arrow{color:var(--ls-accent,#f97316);align-self:center;font-size:22px;font-weight:700}.pd-hub-card-badge{background:linear-gradient(135deg, var(--ls-accent,#f97316), var(--ls-rose,#ec4899));color:#fff;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:800;position:absolute;top:16px;right:16px}.pd-hub-card-badge[data-kind=lock]{color:#6b7280;background:#e5e7eb}.pd-hub-foot{color:var(--ls-muted,#4b5563);border-top:1px solid #1f293714;flex-wrap:wrap;justify-content:space-between;gap:12px;margin-top:auto;padding:20px clamp(20px,4vw,40px);font-size:13.5px;display:flex}.pd-hub-foot a{color:var(--ls-accent-deep,#ea580c);font-weight:700;text-decoration:none}.pd-screen{min-height:100vh}.pd-screen-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:16px;max-width:1100px;margin:0 auto;padding:0 clamp(20px,4vw,40px) 24px;display:flex}.pd-screen-back{color:var(--ls-muted,#4b5563);align-items:center;gap:6px;font-size:14.5px;font-weight:700;text-decoration:none;display:inline-flex}.pd-screen-back:hover{color:var(--ls-accent-deep,#ea580c)}.pd-screen-title{letter-spacing:-.02em;margin:0;font-size:clamp(24px,3.4vw,34px);font-weight:900}.pd-screen-body{max-width:1100px;margin:0 auto;padding:0 clamp(20px,4vw,40px) 56px}.pd-empty{text-align:center;background:#fff;border:1px solid #1f293714;border-radius:18px;justify-items:center;gap:10px;max-width:560px;margin:0 auto;padding:40px 24px;display:grid}.pd-empty h2{color:#1f2937;margin:0;font-size:22px;font-weight:800}.pd-empty p{color:var(--ls-muted,#4b5563);max-width:380px;margin:0}.pd-page{min-height:100vh;font-family:var(--qm-font);color:var(--qm-fg);background:radial-gradient(700px 500px at -10% 0,#d2e0ff 0%,#0000 55%),radial-gradient(700px 500px at 110% 10%,#ffe4b8 0%,#0000 55%),radial-gradient(800px 600px at 50% 110%,#cdf2d8 0%,#0000 55%),linear-gradient(#fffaf3 0%,#f0f5fc 100%);position:relative;overflow-x:clip}.pd-page:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle at 1px 1px,#15192e0d 1px,#0000 0);background-size:24px 24px;position:fixed;inset:0;-webkit-mask-image:radial-gradient(#000 30%,#0000 75%);mask-image:radial-gradient(#000 30%,#0000 75%)}.pd-shell{z-index:1;gap:clamp(20px,3vw,32px);max-width:1180px;margin:0 auto;padding:clamp(20px,4vw,44px);display:grid;position:relative}.pd-topbar{justify-content:space-between;align-items:center;gap:16px;display:flex}.pd-back{color:var(--qm-fg);border:2px solid var(--qm-card-border);box-shadow:var(--qm-shadow-sm);background:#fff;border-radius:999px;align-items:center;gap:8px;padding:11px 16px;font-size:14px;font-weight:700;text-decoration:none;transition:transform .16s,background .16s;display:inline-flex}.pd-back:hover{background:#f4f6fb;transform:translate(-2px)}.pd-title-block{text-align:right}.pd-title-eyebrow{letter-spacing:.16em;color:var(--qm-muted);text-transform:uppercase;font-size:11px;font-weight:700;display:block}.pd-title{letter-spacing:-.02em;color:var(--qm-fg);margin:0;font-size:clamp(20px,2.8vw,26px);font-weight:800}.pd-hero{border:2px solid var(--qm-card-border);border-radius:var(--qm-radius-lg);box-shadow:var(--qm-shadow);background:linear-gradient(135deg,#fff 0%,#eff5ff 60%,#fff7ed 100%);grid-template-columns:1.4fr 1fr;gap:18px;padding:clamp(22px,3vw,32px);display:grid}@media (max-width:760px){.pd-hero{grid-template-columns:1fr}}.pd-hero-illustration{aspect-ratio:16/6;object-fit:cover;border-radius:var(--qm-radius);border:1px solid #0f172a14;grid-column:1/-1;width:100%;display:block;box-shadow:0 12px 30px -22px #0f172a59}.pd-hero h2{letter-spacing:-.02em;margin:0 0 6px;font-size:clamp(22px,3vw,30px);font-weight:800}.pd-hero-sub{color:var(--qm-muted);max-width:50ch;margin:0;font-size:15px;line-height:1.55}.pd-hero-stats{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.pd-hero-stat{border:2px solid var(--qm-card-border);border-radius:var(--qm-radius-sm);text-align:center;background:#fff;padding:12px;position:relative;overflow:hidden}.pd-hero-stat:before{content:"";background:linear-gradient(90deg,#38bdf8,#6366f1);height:4px;position:absolute;inset:0 0 auto}.pd-hero-stat[data-kind=completion]:before{background:linear-gradient(90deg,#34d399,#06b6d4)}.pd-hero-stat[data-kind=streak]:before{background:linear-gradient(90deg,#fbbf24,#f97316)}.pd-hero-stat[data-kind=approvals]:before{background:linear-gradient(90deg,#f472b6,#fb7185)}.pd-hero-stat-value{letter-spacing:-.02em;font-size:clamp(20px,2.6vw,26px);font-weight:800}.pd-hero-stat-label{color:var(--qm-muted);letter-spacing:.06em;text-transform:uppercase;margin-top:2px;font-size:11px;font-weight:700;display:block}.pd-card{border:2px solid var(--qm-card-border);border-radius:var(--qm-radius-lg);box-shadow:var(--qm-shadow);background:#fff;padding:clamp(22px,3vw,32px)}.pd-book-card{background:linear-gradient(135deg,#fffaf0 0%,#fff7ed 50%,#fef3c7 100%)}.pd-book-body{grid-template-columns:160px 1fr;align-items:center;gap:24px;display:grid}@media (max-width:640px){.pd-book-body{grid-template-columns:1fr}}.pd-book-cover{object-fit:cover;border-radius:12px;width:160px;height:auto;display:block;box-shadow:0 14px 32px -16px #0f172a8c}.pd-book-cta{gap:10px;display:grid}.pd-book-note{color:var(--qm-muted);margin:0;font-size:13px}.pd-primary{color:#fff;background:linear-gradient(135deg,#f97316,#ef4444);border-radius:999px;align-self:flex-start;align-items:center;gap:8px;padding:12px 18px;font-weight:800;text-decoration:none;display:inline-flex;box-shadow:0 10px 22px -10px #ef4444b3}.pd-primary:hover{transform:translateY(-1px)}.pd-section-head{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:16px;display:flex}.pd-section-head h3{letter-spacing:-.01em;margin:0;font-size:clamp(17px,2.2vw,21px);font-weight:800}.pd-section-head p{color:var(--qm-muted);margin:0;font-size:13px}.pd-mastery-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;display:grid}.pd-mastery-row{border-radius:var(--qm-radius);background:var(--subject-soft);border:2px solid color-mix(in srgb, var(--subject) 20%, transparent);align-items:center;gap:12px;padding:14px;display:flex}.pd-mastery-row .qm-icon{width:42px;height:42px}.pd-mastery-row .qm-icon svg{width:22px;height:22px}.pd-narrative{border:2px solid var(--qm-card-border);border-radius:var(--qm-radius-lg);box-shadow:var(--qm-shadow);background:linear-gradient(135deg,#fff 0%,#fff7ed 100%);padding:clamp(22px,3vw,32px);position:relative;overflow:hidden}.pd-narrative:after{content:"";filter:blur(40px);opacity:.35;pointer-events:none;background:conic-gradient(from 200deg,#fde68a,#fbcfe8,#c7d2fe,#99f6e4,#fde68a);border-radius:50%;width:200px;height:200px;position:absolute;bottom:-60px;right:-60px}.pd-narrative-meta{letter-spacing:.08em;text-transform:uppercase;color:var(--qm-muted);font-size:11px;font-weight:700}.pd-narrative-text{color:var(--qm-fg);margin:8px 0 0;font-size:clamp(16px,2vw,18px);font-weight:500;line-height:1.55;position:relative}.pd-narrative-meta-fallback{color:var(--qm-muted);margin-top:8px;font-size:11px;font-style:italic}.pd-tips{gap:10px;margin-top:18px;display:grid}.pd-tip{border:2px solid var(--qm-card-border);border-radius:var(--qm-radius);color:var(--qm-fg);background:#ffffffd9;border-left:6px solid #6366f1;align-items:flex-start;gap:12px;padding:14px 16px;font-size:14px;line-height:1.5;display:flex}.pd-tip-num{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;flex-shrink:0;place-items:center;width:28px;height:28px;font-size:13px;font-weight:800;display:grid}.pd-priorities{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px;margin-top:18px;display:grid}.pd-priority{border-radius:var(--qm-radius);background:linear-gradient(160deg, var(--subject-soft) 0%, white 80%);border:2px solid color-mix(in srgb, var(--subject) 22%, transparent);border-left:6px solid var(--subject);padding:14px}.pd-priority-subject{letter-spacing:.06em;text-transform:uppercase;color:var(--subject-accent);align-items:center;gap:6px;margin-bottom:4px;font-size:12px;font-weight:800;display:flex}.pd-priority-subject .qm-monogram,.pd-priority-subject-mono{background:linear-gradient(135deg, var(--subject), var(--subject-accent));color:#fff;border-radius:6px;place-items:center;width:22px;height:22px;font-size:11px;font-weight:800;display:grid}.pd-priority-reason{color:var(--qm-fg);margin:4px 0 0;font-size:13px;line-height:1.5}.pd-approvals-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;display:grid}.pd-approvals-bucket{border-radius:var(--qm-radius);background:linear-gradient(135deg,#fff5f7,#fff);border:2px solid #fbcfe8;padding:16px}.pd-approvals-bucket[data-kind=invites]{background:linear-gradient(135deg,#f0f5ff,#fff);border-color:#c7d2fe}.pd-approvals-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:#be185d;font-size:11px;font-weight:800}.pd-approvals-bucket[data-kind=invites] .pd-approvals-eyebrow{color:#4338ca}.pd-approvals-list{gap:8px;margin:8px 0 0;padding:0;list-style:none;display:grid}.pd-approval-item{border:1px solid var(--qm-card-border);color:var(--qm-fg);background:#fff;border-radius:10px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;font-size:13px;display:flex}.pd-approval-label{flex:1;min-width:0}.pd-approval-status{letter-spacing:.06em;text-transform:uppercase;color:#c2410c;background:#fff7ed;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:800}.pd-approval-item[data-status=approved] .pd-approval-status{color:#047857;background:#ecfdf5}.pd-approval-item[data-status=declined] .pd-approval-status{color:#b91c1c;background:#fef2f2}.pd-approval-actions{flex-shrink:0;gap:6px;display:inline-flex}.pd-action{letter-spacing:.04em;cursor:pointer;border:2px solid var(--qm-card-border);border-radius:8px;padding:6px 10px;font-family:inherit;font-size:12px;font-weight:800;transition:transform .14s,box-shadow .14s,background .14s}.pd-action:hover:not(:disabled){transform:translateY(-1px)}.pd-action:disabled{opacity:.5;cursor:progress}.pd-action--approve{color:#fff;background:linear-gradient(135deg,#16a34a,#06b6d4);border-color:#0000;box-shadow:0 4px 10px -3px #10a34a80}.pd-action--decline{color:#b91c1c;background:#fff;border-color:#fecaca}.pd-action--decline:hover:not(:disabled){background:#fef2f2}.pd-action-error{color:#b91c1c;margin-top:8px;font-size:12px;font-weight:700}.pd-empty-state{color:var(--qm-muted);font-size:13px;font-style:italic}.pd-reflections{gap:10px;display:grid}.pd-reflection{border-radius:var(--qm-radius);background:linear-gradient(135deg,#fffbeb,#fff);border:2px solid #fde68a;gap:6px;padding:14px 16px;display:grid}.pd-reflection-day{letter-spacing:.08em;text-transform:uppercase;color:#92400e;font-size:11px;font-weight:800}.pd-reflection-text{color:var(--qm-fg);margin:0;font-size:14px;font-style:italic;line-height:1.55}.pd-share-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.pd-share-link{border-radius:var(--qm-radius);border:2px solid var(--qm-card-border);color:var(--qm-fg);background:linear-gradient(135deg,#fff,#f0f5fc);align-items:center;gap:12px;padding:16px;font-weight:700;text-decoration:none;transition:transform .16s,box-shadow .16s;display:flex}.pd-share-link:hover{box-shadow:var(--qm-shadow);transform:translateY(-2px)}.pd-share-icon{color:#fff;background:linear-gradient(135deg,#38bdf8,#6366f1);border-radius:12px;flex-shrink:0;place-items:center;width:40px;height:40px;font-weight:800;display:grid}.pd-share-link[data-kind=teacher] .pd-share-icon{background:linear-gradient(135deg,#16a34a,#06b6d4)}.pd-share-link[data-kind=report] .pd-share-icon{background:linear-gradient(135deg,#f97316,#fbbf24)}.pd-share-body{gap:2px;display:grid}.pd-share-title{font-size:14px}.pd-share-sub{color:var(--qm-muted);font-size:12px;font-weight:500}.pd-footer{text-align:center;color:var(--qm-muted);border-top:2px dashed var(--qm-card-border);padding:24px 0 12px;font-size:13px}