:root{--putt-green: #f47f72;--fairway-green: #da6d63;--sun-glow: #f6b27a;--sky-blue: #f8c5bb;--coral-pop: #ff8f7f;--cream: #fff5ef;--card: #fffdfb;--text: #3c201d;--muted: #8d6660;--border: #f1d5cd;--shadow: 0 16px 32px rgba(98, 48, 41, .1);font-family:Inter,system-ui,sans-serif;color:var(--text);background:linear-gradient(180deg,#fff6f1,#ffe9df)}*{box-sizing:border-box}body{margin:0;min-height:100vh}button,input,textarea,select{font:inherit}button{border:none;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.6}input,textarea,select{width:100%;border:1px solid var(--border);border-radius:16px;padding:.9rem 1rem;background:#fff}textarea{resize:vertical}label{display:grid;gap:.35rem;font-weight:600}.topbar h1,h2,h3{font-family:Fredoka,Inter,system-ui,sans-serif;margin:0}.topbar h1{font-size:1.9rem}.eyebrow{margin:0 0 .35rem;font-size:.74rem;font-weight:800;letter-spacing:.12em;color:var(--fairway-green)}.muted{color:var(--muted)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-shell{max-width:820px;margin:0 auto;min-height:100vh;padding:1rem 1rem 5.75rem;position:relative}.page-stack,.request-list,.course-list,.buddy-list,.activity-list,.onboarding-list,.form-stack,.auth-card,.preference-stack,.photo-upload-card,.crop-editor,.crop-controls,.visibility-card{display:grid}.page-stack{gap:1rem}.request-list,.course-list,.buddy-list,.activity-list{gap:.85rem}.onboarding-list{gap:.75rem}.form-stack{gap:.9rem}.auth-card,.preference-stack,.photo-upload-card,.crop-editor,.crop-controls,.visibility-card{gap:.85rem}.visibility-card{gap:.75rem}.topbar{position:relative;display:flex;justify-content:center;align-items:flex-start;margin-bottom:1rem;padding-top:.5rem}.brand-lockup{display:grid;justify-items:center;text-align:center}.brand-logo{display:block;width:min(300px,68vw);height:auto;filter:drop-shadow(0 10px 18px rgba(98,48,41,.16))}.topbar .avatar-button{position:absolute;top:.5rem;right:.5rem}.card-actions{display:flex;gap:.6rem;margin-top:.85rem}.compact-actions{flex-wrap:wrap;justify-content:flex-end}.chip-row{display:flex;gap:.5rem;flex-wrap:wrap}.request-topline,.course-card-topline,.buddy-row,.activity-card-topline,.visibility-header-row,.onboarding-step,.onboarding-step-topline{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.request-topline,.course-card-topline,.activity-card-topline{margin-bottom:.65rem}.onboarding-step-topline{margin-bottom:.35rem}.buddy-row-main{display:flex;align-items:center;gap:.75rem;min-width:0}.photo-upload-controls{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap}.hero-card,.section-card,.request-card,.course-card{background:var(--card);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow)}.section-card,.request-card,.course-card{padding:1rem}.hero-card{padding:1.2rem;background:linear-gradient(135deg,#ff8f7f24,#f6b27a3d)}.request-card.highlighted{border-color:#f47f72a6;box-shadow:0 0 0 4px #f47f7229,var(--shadow)}.chip,.nav-pill,.chip-button{display:inline-flex;align-items:center;justify-content:center;min-height:2.2rem;padding:.45rem .9rem;border-radius:999px;background:#fff;border:1px solid var(--border);color:var(--muted);text-decoration:none}.chip.active,.nav-pill.active,.chip-button.active{background:var(--putt-green);color:#fff;border-color:var(--putt-green)}.avatar-button{width:46px;height:46px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;overflow:hidden;background:#fff;box-shadow:var(--shadow);text-decoration:none;color:inherit;font-weight:800}.avatar-button-image,.avatar-dot,.profile-avatar-image{object-fit:cover}.avatar-button-image{width:100%;height:100%}.avatar-stack{display:flex}.avatar-dot{width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;overflow:hidden;background:var(--sky-blue);color:var(--text);font-weight:800}.reason-badge{padding:.25rem .65rem;border-radius:999px;background:#fff0e2;color:#9d5d40;font-size:.8rem;font-weight:700;white-space:nowrap}.reason-badge.success{background:#f47f7229;color:var(--fairway-green)}.button-secondary{background:#fff!important;color:var(--text)!important;border:1px solid var(--border)}.button-danger{background:#fff1ef!important;color:#b54333!important;border:1px solid #f3c3ba}.card-actions button,.form-stack button{background:var(--putt-green);color:#fff;padding:.8rem 1rem;border-radius:16px;font-weight:700}.button-full{width:100%}.tip-card,.response-panel{display:flex;flex-direction:column;gap:.25rem;padding:.9rem 1rem;border-radius:20px;background:linear-gradient(135deg,#f8c5bb33,#f6b27a2e);border:1px solid rgba(244,127,114,.18)}.response-panel{gap:.65rem}.response-actions .chip-button,.response-summary .chip{min-height:2rem}.foreground-push-toast{position:sticky;bottom:5.25rem;z-index:10;display:grid;gap:.75rem;margin-top:1rem;padding:1rem;background:#fff5eff7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(244,127,114,.16);border-radius:22px;box-shadow:var(--shadow)}.foreground-push-toast strong{display:block;margin-bottom:.25rem}.foreground-push-toast .card-actions{margin-top:0}.bottom-nav{position:fixed;left:50%;bottom:1rem;transform:translate(-50%);display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;width:min(760px,calc(100vw - 1.5rem));padding:.6rem;background:#fff5eff5;border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-pill{font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:.45rem}.nav-pill-icon{font-size:1rem;line-height:1}.nav-pill-label{line-height:1}.error-text,.success-text{margin:0;padding:.8rem 1rem;border-radius:16px;font-weight:700}.error-text{background:#fff1ef;color:#a93d31;border:1px solid #f3c3ba}.success-text{background:#f47f721f;color:var(--fairway-green);border:1px solid rgba(244,127,114,.25)}.field-optional{font-weight:500}.request-course{font-weight:700;margin:.25rem 0}.request-when{color:var(--fairway-green);font-weight:700;margin:0 0 .45rem}.request-context-row{margin-top:.85rem}.request-context-chip{background:#fff7eb}.request-why{margin:.75rem 0 0}.request-tip-card{margin-top:.85rem}.visibility-label{margin:0;font-size:.95rem;font-weight:600}.visibility-badge{font-size:.82rem;font-weight:700;color:var(--muted)}.visibility-helper{margin:.7rem 0 0}.visibility-card{padding:1rem;border:1px solid var(--border);border-radius:20px;background:#fffdf9}.visibility-card-public{background:linear-gradient(135deg,#f8c5bb4d,#f6b27a38);border-color:#f47f7247}.visibility-card-friends_only{background:linear-gradient(135deg,#ff8f7f24,#f6b27a29);border-color:#da6d633d}.visibility-selected-badge{display:inline-flex;align-items:center;border-radius:999px;padding:.35rem .75rem;font-size:.82rem;font-weight:800}.visibility-selected-badge.friends{background:#f47f7229;color:var(--fairway-green)}.visibility-selected-badge.public{background:#f6b27a3d;color:#a34d3f}.visibility-choice-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.visibility-choice{display:grid;justify-items:start;gap:.15rem;min-height:4.2rem;padding:.9rem 1rem!important;border-radius:18px;border:2px solid transparent;background:#fffdfbe0;color:var(--text);box-shadow:inset 0 0 0 1px #e7e2d8e6}.visibility-choice.active{transform:translateY(-1px);box-shadow:0 10px 22px #3e2d1d1a}.visibility-choice.friends-choice.active{background:#ff8f7f2e;border-color:var(--putt-green);color:var(--fairway-green)}.visibility-choice.public-choice.active{background:#f6b27a38;border-color:var(--sun-glow);color:#a34d3f}.visibility-choice-title{font-weight:800}.visibility-choice-subtitle{font-size:.82rem;opacity:.78}.course-meta{margin:0;color:var(--fairway-green);font-weight:700}.course-card.favorite{background:linear-gradient(135deg,#f6b27a2e,#ff8f7f24)}.auth-screen{max-width:560px;margin:0 auto}.auth-hero h2{margin-bottom:.4rem}.auth-toggle-row{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.auth-toggle{background:#fff4ef;color:var(--muted);border:1px solid var(--border);border-radius:16px;padding:.8rem 1rem;font-weight:700}.auth-toggle.active{background:var(--putt-green);color:#fff;border-color:var(--putt-green)}.auth-divider{position:relative;text-align:center;color:var(--muted);font-size:.95rem}.auth-divider:before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:var(--border)}.auth-divider span{position:relative;padding:0 .8rem;background:var(--card)}.config-warning{background:linear-gradient(135deg,#f6b27a2e,#ff8f7f2e)}.form-error,.form-success{margin:0;font-weight:600}.form-error{color:#b54333}.form-success{color:var(--fairway-green)}.profile-card{display:flex;align-items:center;gap:1rem}.profile-avatar{width:3.5rem;height:3.5rem;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--sky-blue);font-size:1.4rem;font-weight:800}.profile-avatar-image{border:3px solid rgba(255,250,246,.88)}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.95rem 1rem;border:1px solid var(--border);border-radius:20px;background:#fffdf9}.toggle-row.disabled{opacity:.7}.toggle-label{display:block;font-weight:700}.toggle-hint{display:block;margin-top:.2rem}.toggle-switch{position:relative;display:inline-flex;align-items:center;width:3.35rem;min-width:3.35rem;height:2rem}.toggle-switch input{position:absolute;inset:0;opacity:0;margin:0;z-index:2}.toggle-slider{position:absolute;inset:0;border-radius:999px;background:#d9e4dd;transition:background .16s ease}.toggle-slider:after{content:"";position:absolute;top:.2rem;left:.2rem;width:1.6rem;height:1.6rem;border-radius:999px;background:#fff;box-shadow:0 4px 10px #21312a2e;transition:transform .16s ease}.toggle-switch.active .toggle-slider{background:var(--putt-green)}.toggle-switch.active .toggle-slider:after{transform:translate(1.35rem)}.toggle-switch.disabled{opacity:.7}.photo-upload-card{padding:1rem;border:1px solid var(--border);border-radius:20px;background:#fffdf9}.crop-preview-shell{width:160px;height:160px;border-radius:999px;overflow:hidden;border:3px solid rgba(244,127,114,.22);background:#fff1ec}.crop-preview-image{width:100%;height:100%;transform-origin:top left}.buddy-avatar{flex-shrink:0}.buddy-meta{margin:.2rem 0 0}.buddy-actions{margin-top:0}.buddy-row,.activity-card{padding:.9rem 1rem;border:1px solid var(--border);border-radius:20px;background:#fffdf9}.onboarding-card{background:linear-gradient(135deg,#f8c5bb2e,#ff8f7f29)}.onboarding-toggle{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;width:100%;padding:0;background:transparent;color:inherit;text-align:left}.onboarding-toggle-icon{flex-shrink:0;font-size:1.2rem;line-height:1;color:var(--fairway-green);padding-top:.2rem}.onboarding-step{padding:.95rem 1rem;border:1px solid var(--border);border-radius:20px;background:#ffffffd1}.onboarding-step.done{background:#ffffffad}@media(max-width:640px){.app-shell{padding-inline:.85rem}.card-actions{grid-template-columns:1fr;display:grid}.request-topline,.course-card-topline,.buddy-row,.onboarding-step,.onboarding-step-topline{align-items:flex-start;flex-direction:column}.topbar{justify-content:center;padding-top:.5rem;margin-bottom:1.25rem}.topbar .avatar-button{position:absolute;top:.35rem;right:.35rem}.brand-logo{width:min(250px,72vw);margin-inline:auto}.bottom-nav{grid-template-columns:repeat(5,minmax(0,1fr));gap:.3rem;width:min(520px,calc(100vw - 1rem));padding:.45rem}.nav-pill{min-width:0;min-height:2.9rem;padding:.45rem .15rem;flex-direction:column;gap:0}.nav-pill-icon{font-size:1.2rem}.nav-pill-label{display:none}}
