:root{--lavender: #D4C5E2;--lavender-deep: #B8A5CC;--lavender-light: #EDE6F4;--sage: #B5C9B3;--sage-deep: #8FB08A;--sage-dark: #5A7A56;--tan: #E8D5B7;--tan-deep: #D4BC94;--tan-dark: #A68B5B;--rose: #E8B4B8;--rose-deep: #D4949A;--mint: #B8D8D0;--mint-deep: #8FC4B8;--butter: #F0E6B8;--butter-deep: #E0D48A;--parchment: #FAF5EB;--parchment-dark: #EDE4D0;--charcoal: #3A3A3A;--charcoal-light: #5A5A5A;--ember: #F4A460;--ember-bright: #FF8C42;--flame: #E85D3A;--flame-glow: rgba(244, 164, 96, .3);--night-sky: #2C2444;--night-mid: #3D3560;--twilight: #5C4F7A;--starlight: #FFF8E7;--font-display: "Cinzel Decorative", serif;--font-heading: "Fredericka the Great", serif;--font-body: "Lora", serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2.5rem;--space-2xl: 4rem;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 30px;--shadow-soft: 0 4px 20px rgba(0, 0, 0, .08);--shadow-medium: 0 8px 32px rgba(0, 0, 0, .12);--shadow-glow: 0 0 30px var(--flame-glow)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow-x:hidden}body{font-family:var(--font-body);color:var(--charcoal);background:var(--night-sky);-webkit-font-smoothing:antialiased}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none}input{font-family:var(--font-body);outline:none}a{text-decoration:none;color:inherit}@keyframes float-up{0%{transform:translateY(0) translate(0) scale(1);opacity:0}10%{opacity:1}90%{opacity:.8}to{transform:translateY(-100vh) translate(30px) scale(.5);opacity:0}}@keyframes float-leaf{0%{transform:translateY(0) translate(0) rotate(0);opacity:0}10%{opacity:.7}50%{transform:translateY(-40vh) translate(60px) rotate(180deg);opacity:.5}to{transform:translateY(-90vh) translate(-20px) rotate(360deg);opacity:0}}@keyframes twinkle{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@keyframes gentle-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes sway{0%,to{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse-glow{0%,to{filter:drop-shadow(0 0 8px rgba(244,164,96,.3))}50%{filter:drop-shadow(0 0 20px rgba(244,164,96,.6))}}@keyframes flicker{0%,to{opacity:1;transform:scaleY(1) scaleX(1)}25%{opacity:.9;transform:scaleY(1.02) scaleX(.98)}50%{opacity:1;transform:scaleY(.98) scaleX(1.02)}75%{opacity:.95;transform:scaleY(1.01) scaleX(.99)}}@keyframes ember-rise{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-60px) scale(.3);opacity:0}}@keyframes smoke-rise{0%{transform:translateY(0) scaleX(1);opacity:.4}50%{transform:translateY(-40px) scaleX(1.5);opacity:.2}to{transform:translateY(-80px) scaleX(2);opacity:0}}@keyframes slide-in-bottom{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes page-enter{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}@keyframes ripple{0%{transform:scale(0);opacity:.5}to{transform:scale(4);opacity:0}}@keyframes hover-bounce{0%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}@keyframes campfire-dance{0%{transform:scaleY(1) scaleX(1) rotate(0)}20%{transform:scaleY(1.08) scaleX(.95) rotate(-1deg)}40%{transform:scaleY(.95) scaleX(1.05) rotate(1deg)}60%{transform:scaleY(1.05) scaleX(.97) rotate(-.5deg)}80%{transform:scaleY(.97) scaleX(1.03) rotate(.5deg)}to{transform:scaleY(1) scaleX(1) rotate(0)}}.parallax-bg{position:fixed;inset:0;z-index:0;overflow:hidden;--mouse-x: 0;--mouse-y: 0}.parallax-bg--night{background:linear-gradient(180deg,#1a1333 0%,var(--night-sky) 30%,var(--night-mid) 60%,var(--twilight) 100%)}.parallax-bg--dusk{background:linear-gradient(180deg,#3D3560 0%,#5C4F7A 20%,#8B7BAA 40%,#C4A882 65%,#E8C9A0 85%,var(--tan) 100%)}.parallax-bg--campsite{background:#0a0a06;transition:background 1s ease;--campsite-sky-bg: #1A2030}.parallax-bg--campsite.campsite--day{background:#87ceeb;--campsite-sky-bg: #87CEEB}.campsite-darkness{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 25%,#1a2030,#0e1218 30%,#080a0c 50%,#040402);transition:opacity 1s ease}.campsite--day .campsite-darkness{background:none}.campsite-sky-sliver{position:absolute;top:0;left:20%;width:60%;height:50%;background:radial-gradient(ellipse at 50% 10%,#1A2A3A 0%,#142030 20%,#0E1620 40%,transparent 70%);z-index:0;transition:background 1s ease}.campsite--day .campsite-sky-sliver{background:none}.campsite-sky-sliver:before{content:"";position:absolute;top:5%;left:30%;width:2px;height:2px;background:#aab8cc;border-radius:50%;box-shadow:40px 8px #aab8cc66,120px 15px #aab8cc99,80px 25px #aab8cc4d,200px 5px #aab8cc80,160px 30px #aab8cc40,50px 35px #aab8cc59,250px 18px #aab8cc66;transition:opacity 1s ease}.campsite--day .campsite-sky-sliver:before{opacity:0}.campsite-sky-objects{position:absolute;top:0;left:20%;width:60%;height:45%;z-index:4;pointer-events:none}.campsite-celestial{position:absolute;top:18%;right:18%;filter:drop-shadow(0 0 12px rgba(200,208,216,.15));pointer-events:auto}.campsite--day .campsite-celestial{filter:drop-shadow(0 0 16px rgba(240,208,96,.4))}.campsite-star{position:absolute;background:#c8d0d8;border-radius:50%;animation:twinkle 3s ease-in-out infinite;box-shadow:0 0 3px #c8d0d866}.campsite-trunks-far,.campsite-trunks-mid,.campsite-trunks-near{position:absolute;top:0;left:0;width:100%;height:100%}.campsite-trunks-far{z-index:1}.campsite-trunks-mid{z-index:2}.campsite-trunks-near{z-index:3}.campsite-eyes{position:absolute;inset:0;z-index:0;pointer-events:none;transition:opacity 1s ease}.forest-eyes{position:absolute;display:flex;align-items:center;animation:eyes-blink var(--duration, 5s) ease-in-out infinite}.forest-eye{border-radius:50%;opacity:.7}@keyframes eyes-blink{0%,42%,48%,to{opacity:.7}44%,46%{opacity:0}85%,87%{opacity:0}}.campsite--day .campsite-trunks-far rect{fill:#5a4a38;opacity:1}.campsite--day .campsite-trunks-far polygon{fill:#2e5a28;opacity:1}.campsite--day .campsite-trunks-mid rect{fill:#4a3a28;opacity:1}.campsite--day .campsite-trunks-mid polygon{fill:#1e6a1e;opacity:1}.campsite--day .campsite-trunks-mid line{stroke:#5a4a38;opacity:1}.campsite--day .campsite-trunks-near rect{fill:#3a2a1e;opacity:1}.campsite--day .campsite-trunks-near line{stroke:#4a3a28;opacity:1}.campsite--day .campsite-trunks-near ellipse{fill:#3a2a1e;stroke:#4a3a28;opacity:1}.campsite--day .campsite-eyes{opacity:0;transition:opacity 1s ease}.campsite-floor{bottom:0;height:50%;background:linear-gradient(180deg,#1a1810,#181610,#1a1810);z-index:4;border-top:1px solid #2A2820;transition:background 1s ease,border-color 1s ease}.campsite--day .campsite-floor{background:linear-gradient(180deg,#5c4a32,#4a3a28 30%,#3e3020);border-top:1px solid #6A5A42}.campsite-ground-detail{position:absolute;bottom:0;left:0;width:100%;height:50%;z-index:5;pointer-events:none}.campsite--day .campsite-ground-detail path{stroke:#4a3a28}.campsite--day .campsite-ground-detail polygon{fill:#3e3020;stroke:#4a3a28}.campsite--day .campsite-ground-detail line{stroke:#4a3a28}.campsite--day .campsite-ground-detail g line{stroke:#3e3020}.campsite-mist{position:absolute;bottom:10%;left:0;width:100%;height:30%;background:radial-gradient(ellipse at 50% 100%,rgba(180,180,160,.06) 0%,rgba(140,140,120,.03) 40%,transparent 70%);z-index:5;pointer-events:none}.campsite--day .campsite-mist{opacity:0}.parallax-layer{position:absolute;width:calc(100% + 80px);left:-40px;transition:transform .3s ease-out}.parallax-layer--stars{inset:0;transform:translate(calc(var(--mouse-x) * -3px),calc(var(--mouse-y) * -3px))}.star{position:absolute;background:var(--starlight);border-radius:50%;animation:twinkle var(--duration, 3s) ease-in-out infinite;box-shadow:0 0 6px #fff8e799}.parallax-layer--mountains-far{bottom:0;height:55%;transform:translate(calc(var(--mouse-x) * -8px),calc(var(--mouse-y) * -4px))}.parallax-bg--night .parallax-layer--mountains-far path{fill:#3a2f55}.parallax-bg--dusk .parallax-layer--mountains-far path{fill:#7b6b9a}.parallax-bg--campsite .parallax-layer--mountains-far path{fill:transparent}.parallax-layer--mountains-near{bottom:0;height:45%;transform:translate(calc(var(--mouse-x) * -15px),calc(var(--mouse-y) * -6px))}.parallax-bg--night .parallax-layer--mountains-near path{fill:#2d2648}.parallax-bg--dusk .parallax-layer--mountains-near path{fill:#6a5a8a}.parallax-bg--campsite .parallax-layer--mountains-near path{fill:transparent}.parallax-layer--trees{bottom:0;height:35%;transform:translate(calc(var(--mouse-x) * -22px),calc(var(--mouse-y) * -8px))}.parallax-bg--night .parallax-layer--trees path{fill:#1e1a32}.parallax-bg--dusk .parallax-layer--trees path{fill:#4a5a48}.parallax-bg--campsite .parallax-layer--trees path{fill:transparent}.parallax-layer--ground{bottom:0;height:15%;transform:translate(calc(var(--mouse-x) * -30px))}.parallax-bg--night .parallax-layer--ground{background:linear-gradient(180deg,#1a1530,#141020)}.parallax-bg--dusk .parallax-layer--ground{background:linear-gradient(180deg,#3a4a38,#2a3628)}.parallax-bg--campsite .parallax-layer--ground{background:transparent}.floating-leaf{position:absolute;animation:float-leaf 10s ease-in-out infinite;pointer-events:none;z-index:2}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative}.login-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);padding:var(--space-xl)}.login-header{text-align:center;animation:fade-in-up .8s ease backwards}.login-emblem{margin-bottom:var(--space-md);animation:gentle-bob 5s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(244,164,96,.3))}.login-title{font-family:var(--font-display);font-size:3rem;font-weight:900;color:var(--parchment);letter-spacing:.08em;text-shadow:0 2px 10px rgba(244,164,96,.3),0 0 40px rgba(244,164,96,.15)}.login-tagline{font-family:var(--font-body);font-style:italic;font-size:1.05rem;color:var(--lavender-light);margin-top:var(--space-xs);opacity:.8}.login-card{background:linear-gradient(145deg,#faf5ebf2,#ede4d0f2);border-radius:var(--radius-lg);padding:0;width:380px;max-width:90vw;overflow:hidden;animation:fade-in-up .8s ease .15s backwards;box-shadow:0 20px 60px #00000059,0 0 0 1px #a88b5b33,inset 0 1px #ffffff80;position:relative}.login-card:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 60%,rgba(168,139,91,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 30%,rgba(168,139,91,.04) 0%,transparent 50%);pointer-events:none}.login-card-header{display:flex;border-bottom:1px solid rgba(168,139,91,.15);position:relative}.login-tab{flex:1;padding:14px;font-family:var(--font-body);font-weight:600;font-size:.9rem;color:var(--charcoal-light);background:none;border:none;cursor:pointer;transition:all .3s ease;position:relative}.login-tab--active{color:var(--charcoal)}.login-tab--active:after{content:"";position:absolute;bottom:-1px;left:20%;width:60%;height:2px;background:var(--sage-deep);border-radius:2px}.login-tab:hover:not(.login-tab--active){color:var(--charcoal);background:#00000005}.login-form{padding:var(--space-lg) var(--space-xl) var(--space-md);display:flex;flex-direction:column;gap:var(--space-md);position:relative}.login-field{display:flex;flex-direction:column;gap:6px}.login-field--appear{animation:fade-in-up .3s ease}.login-label{font-size:.8rem;font-weight:600;color:var(--charcoal-light);letter-spacing:.02em}.login-optional{font-weight:400;opacity:.6;font-style:italic}.login-input{padding:12px 16px;border:2px solid var(--tan-deep);border-radius:var(--radius-md);font-size:.95rem;background:#fff9;color:var(--charcoal);transition:border-color .3s ease,box-shadow .3s ease}.login-input:focus{border-color:var(--lavender-deep);box-shadow:0 0 0 3px #b8a5cc40}.login-input::placeholder{color:var(--tan-deep);font-style:italic}.login-error{font-size:.85rem;color:var(--flame);animation:fade-in .2s ease}.login-submit{margin-top:var(--space-xs);padding:14px;font-family:var(--font-body);font-weight:700;font-size:1rem;color:#fff;background:linear-gradient(135deg,var(--sage-deep),var(--sage-dark));border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #5a7a5659;letter-spacing:.02em}.login-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #5a7a5673}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.5;cursor:not-allowed}.login-loading{font-style:italic}.login-footer{text-align:center;padding:var(--space-md) var(--space-xl) var(--space-lg);font-size:.85rem;color:var(--charcoal-light);position:relative}.login-switch{background:none;border:none;color:var(--sage-dark);font-weight:700;cursor:pointer;font-size:inherit;font-family:inherit;text-decoration:underline;text-underline-offset:2px;transition:color .2s ease}.login-switch:hover{color:var(--sage-deep)}.login-decoration{animation:fade-in 1s ease .5s backwards;opacity:.5}.home-page{min-height:100vh;position:relative}.home-content{position:relative;z-index:10;min-height:100vh;display:flex;flex-direction:column}.home-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-xl);background:#0a08144d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,248,231,.08)}.home-brand{display:flex;align-items:center;gap:var(--space-sm)}.home-brand-text{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--parchment);letter-spacing:.05em}.home-brand-icon{filter:drop-shadow(0 0 8px rgba(244,164,96,.3))}.home-user{display:flex;align-items:center;gap:var(--space-md)}.home-user-btn{display:flex;align-items:center;gap:var(--space-sm);background:#ffffff0f;border:1px solid rgba(255,248,231,.12);border-radius:var(--radius-xl);padding:4px 14px 4px 4px;cursor:pointer;transition:all .3s ease}.home-user-btn:hover{background:#ffffff1f;border-color:#fff8e740}.home-user-avatar{flex-shrink:0}.home-user-name{font-size:.85rem;font-family:var(--font-body);color:var(--lavender-light)}.home-logout{font-size:.8rem;font-weight:600;color:var(--rose);background:#e8b4b81a;border:1px solid rgba(232,180,184,.25);padding:6px 14px;border-radius:var(--radius-xl);cursor:pointer;transition:all .3s ease}.home-logout:hover{background:#e8b4b833;border-color:#e8b4b866}.home-hero{text-align:center;padding:var(--space-2xl) var(--space-xl) var(--space-xl);animation:fade-in-up .6s ease backwards}.home-title{font-family:var(--font-display);font-size:2.2rem;font-weight:900;color:var(--parchment);letter-spacing:.04em;text-shadow:0 2px 12px rgba(0,0,0,.3)}.home-subtitle{font-family:var(--font-body);font-style:italic;font-size:1rem;color:var(--lavender-light);margin-top:var(--space-xs);opacity:.7}.home-trips{flex:1;padding:0 var(--space-xl) var(--space-2xl);max-width:720px;width:100%;margin:0 auto}.home-grid{display:flex;flex-direction:column;gap:var(--space-sm)}.trip-card-wrapper{position:relative}.trip-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:#faf5ebeb;border:1px solid rgba(168,139,91,.2);border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;animation:fade-in-up .5s ease backwards;text-align:left;width:100%;box-shadow:0 4px 16px #00000026;position:relative;z-index:2}.trip-card:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(168,139,91,.04) 0%,transparent 50%);pointer-events:none}.trip-card:hover{transform:translateY(-2px) translate(4px);box-shadow:0 8px 28px #0003;border-color:#a88b5b59}.trip-card__icon{flex-shrink:0}.trip-card__icon--new{opacity:.6}.trip-card__info{flex:1;min-width:0}.trip-card__name{font-family:var(--font-heading);font-size:1.15rem;color:var(--charcoal);margin-bottom:2px}.trip-card__name--new{color:var(--sage-dark)}.trip-card__date{font-size:.78rem;color:var(--charcoal-light);opacity:.7}.trip-card__arrow{flex-shrink:0;color:var(--tan-deep);transition:transform .3s ease,color .3s ease}.trip-card__delete-zone{position:absolute;left:calc(100% - 10px);top:-2px;bottom:2px;width:0;overflow:hidden;transition:width .3s ease;display:flex;align-items:center;justify-content:center;background:#d94f3b;border-radius:0 var(--radius-md) var(--radius-md) 0;z-index:1;box-shadow:2px 0 8px #d94f3b4d}.trip-card-wrapper:hover .trip-card__delete-zone{width:62px;transition:width .3s ease .6s}.trip-card__delete{background:none;border:none;cursor:pointer;color:#fff;padding:8px;border-radius:50%;transition:all .2s ease;margin-left:10px}.trip-card__delete:hover{background:#fff3}.trip-card__leave-zone{position:absolute;left:calc(100% - 10px);top:-2px;bottom:2px;width:0;overflow:hidden;transition:width .3s ease;display:flex;align-items:center;justify-content:center;background:var(--charcoal-light);border-radius:0 var(--radius-md) var(--radius-md) 0;z-index:1;box-shadow:2px 0 8px #0003}.trip-card-wrapper:hover .trip-card__leave-zone{width:62px;transition:width .3s ease .6s}.trip-card__leave{background:none;border:none;cursor:pointer;color:#fff;padding:8px;border-radius:50%;transition:all .2s ease;margin-left:10px}.trip-card__leave:hover{background:#fff3}.trip-card__join{flex-shrink:0;display:flex;align-items:center;gap:4px;color:var(--sage-deep);font-family:var(--font-body);font-weight:700;font-size:.8rem;transition:transform .3s ease,color .3s ease}.trip-card:hover .trip-card__join{transform:scale(1.1);color:var(--sage-dark)}.trip-card__join--loading{opacity:.5}.trip-card__join-text{letter-spacing:.03em}.trip-card:hover .trip-card__arrow{transform:translate(4px);color:var(--sage-deep)}.trip-card__plus{flex-shrink:0;font-size:1.5rem;color:var(--sage);font-weight:300;transition:transform .3s ease}.trip-card:hover .trip-card__plus{transform:scale(1.2)}.trip-card--new{background:#faf5eb99;border-style:dashed;border-color:#8fb08a4d}.trip-card--new:hover{background:#faf5ebd9;border-color:#8fb08a80}.trip-card--form{flex-direction:column;align-items:stretch;gap:var(--space-md);padding:var(--space-lg);cursor:default}.trip-create-input{width:100%;padding:12px 16px;font-size:1rem;font-family:var(--font-body);border:2px solid var(--tan-deep);border-radius:var(--radius-md);background:#fff9;color:var(--charcoal);transition:border-color .3s ease,box-shadow .3s ease}.trip-create-input:focus{border-color:var(--sage-deep);box-shadow:0 0 0 3px #8fb08a40;outline:none}.trip-create-input::placeholder{color:var(--tan-deep);font-style:italic}.trip-create-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.trip-create-cancel{padding:8px 16px;font-size:.85rem;color:var(--charcoal-light);background:none;border:1px solid var(--tan-deep);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-body);transition:background .2s ease}.trip-create-cancel:hover{background:#0000000a}.trip-create-submit{padding:8px 20px;font-size:.85rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--sage-deep),var(--sage-dark));border:none;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-body);box-shadow:0 4px 12px #5a7a564d;transition:all .3s ease}.trip-create-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #5a7a5666}.trip-create-submit:disabled{opacity:.5;cursor:not-allowed}.home-loading{text-align:center;padding:var(--space-2xl);color:var(--lavender-light);opacity:.7;font-style:italic;animation:fade-in .3s ease}.home-loading-flame{width:20px;height:30px;margin:0 auto var(--space-md);background:radial-gradient(ellipse at bottom,var(--ember) 0%,transparent 70%);border-radius:50%/60% 60% 40% 40%;animation:campfire-dance .8s ease-in-out infinite}.home-error{text-align:center;color:var(--rose);background:#e8b4b826;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:.9rem}.home-empty{text-align:center;padding:var(--space-2xl);animation:fade-in .5s ease}.home-empty-icon{opacity:.5;margin-bottom:var(--space-md);animation:gentle-bob 4s ease-in-out infinite}.home-empty-text{color:var(--lavender-light);font-style:italic;opacity:.6}.modal-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#0a0814b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fade-in .25s ease}.modal-content{background:linear-gradient(145deg,#faf5ebf7,#ede4d0f7);border:1px solid rgba(168,139,91,.3);border-radius:var(--radius-lg);padding:var(--space-xl) var(--space-xl) var(--space-lg);max-width:420px;width:90%;text-align:center;animation:scale-in .3s ease;box-shadow:0 20px 60px #0006,0 0 0 1px #fff8e71a,inset 0 1px #fff6;position:relative;overflow:hidden}.modal-content:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(168,139,91,.06) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(168,139,91,.04) 0%,transparent 50%);pointer-events:none}.modal-content--coming-soon{border-color:#d4bc9466}.modal-icon-large{margin-bottom:var(--space-md)}.modal-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--charcoal);margin-bottom:var(--space-sm);position:relative}.modal-flavor{font-family:var(--font-body);font-style:italic;font-size:1rem;color:var(--charcoal-light);margin-bottom:var(--space-md);line-height:1.5}.modal-divider{display:flex;justify-content:center;margin-bottom:var(--space-md);opacity:.5}.modal-subtitle{font-family:var(--font-body);font-size:.9rem;color:var(--charcoal-light);margin-bottom:var(--space-lg);line-height:1.5;position:relative}.modal-form{display:flex;flex-direction:column;gap:var(--space-md);position:relative}.modal-input{width:100%;padding:12px 16px;font-size:.95rem;border:2px solid var(--tan-deep);border-radius:var(--radius-md);background:#ffffffb3;color:var(--charcoal);transition:border-color .3s ease,box-shadow .3s ease}.modal-input:focus{border-color:var(--lavender-deep);box-shadow:0 0 0 3px #b8a5cc4d}.modal-input::placeholder{color:var(--tan-deep);font-style:italic}.modal-error{font-size:.85rem;color:var(--flame);text-align:left}.modal-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.modal-btn{font-family:var(--font-body);font-weight:600;font-size:.9rem;padding:10px 22px;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,var(--sage-deep),var(--sage-dark));color:#fff;box-shadow:0 4px 12px #5a7a564d}.modal-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #5a7a5666}.modal-btn:disabled{opacity:.5;cursor:not-allowed}.modal-btn--secondary{background:transparent;color:var(--charcoal-light);box-shadow:none;border:1px solid var(--tan-deep)}.modal-btn--secondary:hover{background:#0000000a;box-shadow:none}.modal-btn--danger{background:linear-gradient(135deg,var(--rose-deep),#C44A30);color:#fff;box-shadow:0 4px 12px #c44a304d}.modal-btn--danger:hover:not(:disabled){box-shadow:0 6px 20px #c44a3066}.modal-email-row{display:flex;flex-direction:column;gap:4px}.modal-email-input-wrap{display:flex;align-items:center;gap:8px}.modal-email-input-wrap .modal-input{flex:1}.modal-email-remove{background:none;border:none;cursor:pointer;font-size:1.4rem;color:var(--charcoal-light);padding:4px 8px;line-height:1;border-radius:var(--radius-sm);transition:color .2s ease,background .2s ease}.modal-email-remove:hover{color:var(--flame);background:#e85d3a1a}.modal-add-email{background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:.85rem;font-weight:600;color:var(--sage-deep);padding:6px 0;text-align:left;transition:color .2s ease}.modal-add-email:hover{color:var(--sage-dark)}.campfire-container{position:relative;width:140px;height:160px;z-index:10;margin-top:90px}.campfire-ground-glow{position:absolute;bottom:10px;left:50%;transform:translate(-50%);width:200px;height:60px;background:radial-gradient(ellipse,rgba(244,164,96,.35) 0%,rgba(232,93,58,.15) 40%,transparent 70%);border-radius:50%;animation:pulse-glow 3s ease-in-out infinite;filter:blur(8px)}.campfire-smoke{position:absolute;top:-20px;left:0;width:100%;height:80px;pointer-events:none}.smoke-particle{position:absolute;bottom:0;width:20px;height:20px;background:radial-gradient(circle,rgba(180,180,180,.25) 0%,transparent 70%);border-radius:50%;animation:smoke-rise 3.5s ease-out infinite}.campfire-flames{position:absolute;bottom:18px;left:50%;transform:translate(-50%);width:60px;height:70px}.flame{position:absolute;bottom:0;left:50%;border-radius:50%/60% 60% 40% 40%;transform-origin:bottom center}.flame--outer{width:46px;height:60px;margin-left:-25px;background:radial-gradient(ellipse at bottom,#f4a460,#e85d3a,#e85d3a00 80%);animation:campfire-dance .8s ease-in-out infinite;filter:blur(2px)}.flame--mid{width:34px;height:48px;margin-left:-19px;background:radial-gradient(ellipse at bottom,#ff8c42,#f4a460 50%,#f4a46000 85%);animation:campfire-dance .6s ease-in-out infinite .1s;filter:blur(1px)}.flame--inner{width:22px;height:38px;margin-left:-13px;background:radial-gradient(ellipse at bottom,#ffd166,#ff8c42 60%,#ff8c4200 90%);animation:campfire-dance .5s ease-in-out infinite .2s}.flame--core{width:12px;height:26px;margin-left:-7px;background:radial-gradient(ellipse at bottom,#fff8e7,#ffd166 50%,#ffd16600 85%);animation:campfire-dance .4s ease-in-out infinite .15s}.campfire-embers{position:absolute;bottom:38px;left:0;width:100%;height:60px;pointer-events:none}.ember{position:absolute;bottom:0;width:3px;height:3px;background:#ffd166;border-radius:50%;box-shadow:0 0 4px #ff8c42;animation:ember-rise 2s ease-out infinite}.campfire-logs{position:absolute;bottom:15px;left:50%;transform:translate(-50%);width:80px;height:30px}.log{position:absolute;border-radius:4px;background:linear-gradient(90deg,#5a3a1e,#7a5230,#5a3a1e);box-shadow:inset 0 -2px 4px #0000004d,0 2px 4px #0000004d}.log--1{width:60px;height:10px;bottom:2px;left:2px;transform:rotate(-15deg)}.log--2{width:60px;height:10px;bottom:2px;right:2px;transform:rotate(15deg)}.log--3{width:50px;height:9px;bottom:10px;left:50%;margin-left:-25px;transform:rotate(-3deg)}.campfire-stones{position:absolute;bottom:20px;left:50%;transform:translate(-50%);width:0;height:0;z-index:-1}.stone{position:absolute;width:14px;height:11px;background:linear-gradient(135deg,#6b6b7b,#4a4a58);border-radius:50%;box-shadow:inset 0 -2px 3px #0006,0 1px 2px #0000004d}.camper-avatar{position:absolute;display:flex;flex-direction:column-reverse;align-items:center;gap:0;animation:fade-in .4s ease-out backwards;transition:transform .4s ease-out;z-index:5}.camper-avatar--add{background:none;border:none;cursor:pointer;padding:0;transition:transform .4s ease-out}.camper-avatar--add:hover{transform:translate(var(--tx, 0),var(--ty, 0)) scale(1.08)}.camper-avatar--add:hover .avatar-figure--ghost{filter:drop-shadow(0 0 12px rgba(255,248,231,.4))}.camper-avatar--add:hover .avatar-name--ghost{color:#fff8e7cc}.avatar-figure{position:relative;animation:gentle-bob 4s ease-in-out infinite;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.avatar-figure--ghost{animation:gentle-bob 4s ease-in-out infinite;opacity:.6;transition:filter .3s ease,opacity .3s ease}.camper-avatar--add:hover .avatar-figure--ghost{opacity:1}.avatar-name{font-family:var(--font-body);font-size:.7rem;font-weight:600;color:var(--parchment);text-shadow:0 1px 4px rgba(0,0,0,.6);background:#00000059;padding:2px 8px;border-radius:8px;white-space:nowrap;max-width:100px;overflow:hidden;text-overflow:ellipsis;margin-bottom:5px}.avatar-name--ghost{color:#fff8e766;background:#0003;transition:color .3s ease;font-family:var(--font-body);font-size:.65rem}.avatar-remove{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:none;border:none;cursor:pointer;padding:0;opacity:0;transition:opacity .2s ease,transform .2s ease;z-index:20}.camper-avatar:hover .avatar-remove{opacity:1}.avatar-remove:hover{transform:translate(-50%,-50%) scale(1.1)}.camper-avatar--pending .avatar-figure{opacity:.6}.avatar-name--pending{color:#fff8e766;background:#0003;font-style:italic;font-size:.6rem}.camper-avatar--failed{opacity:.7}.camper-avatar--failed .avatar-figure{filter:drop-shadow(0 0 8px rgba(232,93,58,.5))}.camper-avatar--failed .avatar-figure svg{filter:hue-rotate(-20deg) saturate(.3)}.avatar-name--failed{color:#e85d3a;background:#e85d3a33;font-style:italic;font-size:.6rem;border:1px solid rgba(232,93,58,.3)}.avatar-name--email{max-width:120px}.avatar-eyes-shift{animation:eyes-shift 6s ease-in-out infinite}@keyframes eyes-shift{0%,78%,to{transform:translate(0)}82%{transform:translate(.9px)}86%,89%{transform:translate(.9px)}92%,96%{transform:translate(-.5px)}99%{transform:translate(0)}}.avatar-fire-glow{position:absolute;top:0;left:50%;transform:translate(-50%);width:48px;height:64px;background:radial-gradient(ellipse at center bottom,rgba(244,164,96,.15) 0%,transparent 70%);pointer-events:none;animation:pulse-glow 3s ease-in-out infinite}.interactable-item{position:absolute;background:none;border:none;cursor:pointer;padding:0;transform:translate(-50%,-50%);z-index:8;transition:transform .3s ease,filter .3s ease}.interactable-item:hover{transform:translate(-50%,-50%) scale(1.08)}.interactable-item__glow{position:absolute;inset:-20px;border-radius:50%;background:radial-gradient(circle,rgba(255,248,231,.15) 0%,transparent 70%);opacity:0;transition:opacity .4s ease;pointer-events:none}.interactable-item--hovered .interactable-item__glow{opacity:1;animation:pulse-glow 2s ease-in-out infinite}.interactable-item__content{position:relative;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4));transition:filter .3s ease}.interactable-item--hovered .interactable-item__content{filter:drop-shadow(0 4px 12px rgba(0,0,0,.4)) drop-shadow(0 0 16px rgba(244,164,96,.4))}.interactable-item__tooltip{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%) translateY(8px);white-space:nowrap;font-family:var(--font-body);font-size:.8rem;font-weight:600;color:var(--parchment);background:#1a1333e6;border:1px solid rgba(255,248,231,.15);padding:6px 14px;border-radius:20px;opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 20px #0006}.interactable-item__tooltip--visible{opacity:1;transform:translate(-50%) translateY(0)}.tooltip-icon{margin-right:4px;color:var(--ember)}.gear-modal-overlay{z-index:100}.gear-modal{background:linear-gradient(155deg,#faf5ebfa,#f0e8d6fa 40%,#ede4d0fa);border:1px solid rgba(168,139,91,.3);border-radius:var(--radius-lg);max-width:720px;width:94%;max-height:85vh;display:flex;flex-direction:column;animation:scale-in .3s ease;box-shadow:0 24px 80px #00000073,0 0 0 1px #fff8e71a,inset 0 1px #ffffff80;position:relative;overflow:hidden}.gear-modal:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 15% 20%,rgba(168,139,91,.07) 0%,transparent 50%),radial-gradient(ellipse at 85% 80%,rgba(168,139,91,.05) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(139,120,80,.03) 0%,transparent 70%);pointer-events:none;z-index:0}.gear-modal:after{content:"";position:absolute;inset:6px;border:1px dashed rgba(168,139,91,.15);border-radius:calc(var(--radius-lg) - 4px);pointer-events:none;z-index:0}.gear-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid rgba(168,139,91,.15);position:relative;z-index:1}.gear-modal-header-left{display:flex;align-items:center;gap:var(--space-md)}.gear-modal-icon{flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.gear-modal-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--charcoal);letter-spacing:.02em}.gear-modal-subtitle{font-family:var(--font-body);font-size:.8rem;color:var(--charcoal-light);font-style:italic;margin-top:2px}.gear-modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#0000000a;color:var(--charcoal-light);transition:all .2s ease;flex-shrink:0}.gear-modal-close:hover{background:#00000014;color:var(--charcoal)}.gear-overall-progress{padding:0 var(--space-xl);position:relative;z-index:1}.gear-overall-bar{height:3px;background:#a88b5b1f;border-radius:2px;overflow:hidden}.gear-overall-fill{height:100%;background:linear-gradient(90deg,var(--sage-deep),var(--sage));border-radius:2px;transition:width .5s ease}.gear-modal-body{flex:1;overflow-y:auto;padding:var(--space-md) var(--space-xl) var(--space-xl);position:relative;z-index:1}.gear-modal-body::-webkit-scrollbar{width:6px}.gear-modal-body::-webkit-scrollbar-track{background:transparent}.gear-modal-body::-webkit-scrollbar-thumb{background:#a88b5b33;border-radius:3px}.gear-modal-body::-webkit-scrollbar-thumb:hover{background:#a88b5b59}.gear-section{--section-accent: var(--sage);margin-bottom:var(--space-sm)}.gear-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-sm) var(--space-sm);background:none;border:none;cursor:pointer;border-radius:var(--radius-sm);transition:background .2s ease}.gear-section-header:hover{background:#00000008}.gear-section-title-row{display:flex;align-items:center;gap:var(--space-sm)}.gear-section-chevron{color:var(--charcoal-light);transition:transform .25s ease;flex-shrink:0}.gear-section-chevron--open{transform:rotate(90deg)}.gear-section-title{font-family:var(--font-body);font-size:.95rem;font-weight:700;color:var(--charcoal)}.gear-section-subtitle{font-family:var(--font-body);font-size:.75rem;color:var(--charcoal-light);font-style:italic}.gear-section-stats{display:flex;align-items:center;gap:var(--space-sm)}.gear-section-count{font-family:var(--font-body);font-size:.75rem;font-weight:600;color:var(--charcoal-light);white-space:nowrap}.gear-progress-bar{width:48px;height:4px;background:#0000000f;border-radius:2px;overflow:hidden}.gear-progress-fill{height:100%;background:var(--section-accent, var(--sage-deep));border-radius:2px;transition:width .4s ease}.gear-section-body{padding:var(--space-xs) 0 var(--space-sm) calc(var(--space-sm) + 16px + var(--space-sm));animation:gear-section-expand .2s ease}@keyframes gear-section-expand{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.gear-category-group{margin-bottom:var(--space-xs)}.gear-category-label{display:flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--tan-dark);padding:var(--space-xs) 0 2px}.gear-category-icon{font-size:.65rem;opacity:.7}.gear-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-sm);transition:background .15s ease}.gear-item:hover{background:#00000006}.gear-item:hover .gear-item-actions{opacity:1}.gear-item--packed .gear-item-name{text-decoration:line-through;color:var(--charcoal-light);opacity:.6}.gear-item--packed .gear-item-category-icon{opacity:.35}.gear-item--packed .gear-item-qty{opacity:.4}.gear-check{width:18px;height:18px;border-radius:4px;border:2px solid var(--tan-deep);background:#fff9;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;padding:0;color:#fff}.gear-check:hover{border-color:var(--sage-deep)}.gear-check--checked{background:var(--sage-deep);border-color:var(--sage-deep)}.gear-item-category-icon{font-size:.7rem;color:var(--tan-dark);width:14px;text-align:center;flex-shrink:0}.gear-item-name{font-family:var(--font-body);font-size:.85rem;color:var(--charcoal);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:all .2s ease}.gear-item-qty{font-family:var(--font-body);font-size:.75rem;font-weight:600;color:var(--charcoal-light);background:#0000000a;padding:1px 6px;border-radius:8px;flex-shrink:0}.gear-item-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s ease;flex-shrink:0}.gear-item-edit,.gear-item-delete{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:6px;background:none;color:var(--charcoal-light);cursor:pointer;transition:all .15s ease;padding:0}.gear-item-edit:hover{background:#0000000f;color:var(--charcoal)}.gear-item-delete:hover{background:#e85d3a14;color:var(--flame)}.gear-item--editing{background:#ffffff80;border:1px solid rgba(168,139,91,.2);padding:6px 8px;gap:6px}.gear-item-edit-name{flex:1;min-width:0;font-family:var(--font-body);font-size:.85rem;padding:4px 8px;border:1px solid var(--tan-deep);border-radius:4px;background:#ffffffb3;color:var(--charcoal)}.gear-item-edit-name:focus{border-color:var(--lavender-deep);box-shadow:0 0 0 2px #b8a5cc33}.gear-item-edit-category{font-family:var(--font-body);font-size:.75rem;padding:4px;border:1px solid var(--tan-deep);border-radius:4px;background:#ffffffb3;color:var(--charcoal);cursor:pointer}.gear-item-edit-qty{display:flex;align-items:center;gap:2px}.gear-item-edit-actions{display:flex;gap:2px}.gear-save-btn,.gear-cancel-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:.85rem;font-weight:700;cursor:pointer;padding:0;transition:all .15s ease}.gear-save-btn{background:var(--sage-deep);color:#fff}.gear-save-btn:hover{background:var(--sage-dark)}.gear-cancel-btn{background:#0000000f;color:var(--charcoal-light)}.gear-cancel-btn:hover{background:#0000001a}.gear-add-qty,.gear-item-edit-qty{display:flex;align-items:center;gap:2px}.gear-qty-btn{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:4px;background:#0000000d;color:var(--charcoal);font-size:.85rem;font-weight:700;cursor:pointer;padding:0;transition:background .15s ease;line-height:1}.gear-qty-btn:hover:not(:disabled){background:#0000001a}.gear-qty-btn:disabled{opacity:.3;cursor:not-allowed}.gear-qty-value{font-family:var(--font-body);font-size:.8rem;font-weight:600;color:var(--charcoal);min-width:20px;text-align:center}.gear-add-form{display:flex;align-items:center;gap:6px;margin-top:var(--space-sm);padding:6px 0}.gear-add-input{flex:1;min-width:0;font-family:var(--font-body);font-size:.85rem;padding:6px 10px;border:1px dashed rgba(168,139,91,.3);border-radius:var(--radius-sm);background:#ffffff4d;color:var(--charcoal);transition:all .2s ease}.gear-add-input:focus{border-style:solid;border-color:var(--sage-deep);background:#fff9;box-shadow:0 0 0 2px #8fb08a26}.gear-add-input::placeholder{color:var(--tan-deep);font-style:italic}.gear-add-category{font-family:var(--font-body);font-size:.75rem;padding:6px 4px;border:1px dashed rgba(168,139,91,.3);border-radius:var(--radius-sm);background:#ffffff4d;color:var(--charcoal);cursor:pointer}.gear-add-category:focus{border-style:solid;border-color:var(--sage-deep)}.gear-add-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,var(--sage-deep),var(--sage-dark));color:#fff;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s ease;flex-shrink:0;padding:0;box-shadow:0 2px 8px #5a7a5640}.gear-add-btn:hover:not(:disabled){transform:scale(1.1);box-shadow:0 4px 12px #5a7a5659}.gear-add-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}.gear-day-tabs{display:flex;align-items:center;gap:4px;padding:var(--space-sm) 0 var(--space-xs);overflow-x:auto;scrollbar-width:none}.gear-day-tabs::-webkit-scrollbar{display:none}.gear-day-tab{font-family:var(--font-body);font-size:.78rem;font-weight:600;padding:6px 14px;border-radius:20px;border:1px solid rgba(168,139,91,.2);background:#ffffff4d;color:var(--charcoal-light);cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.gear-day-tab:hover{background:#ffffff80;border-color:#a88b5b59;color:var(--charcoal)}.gear-day-tab--active{background:var(--sage-deep);border-color:var(--sage-deep);color:#fff;box-shadow:0 2px 8px #5a7a5640}.gear-day-tab--active:hover{background:var(--sage-dark);border-color:var(--sage-dark);color:#fff}.gear-day-tab--add{width:30px;height:30px;padding:0;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;border-style:dashed;color:var(--tan-dark)}.gear-day-tab--add:hover{border-style:solid;background:#8fb08a1f;border-color:var(--sage-deep);color:var(--sage-deep)}.gear-divider{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) 0}.gear-divider-label{font-family:var(--font-display);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--tan-dark);white-space:nowrap}.gear-empty{font-family:var(--font-body);font-size:.85rem;font-style:italic;color:var(--charcoal-light);opacity:.6;padding:var(--space-sm) 0}.gear-loading{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--charcoal-light);font-style:italic;font-size:.9rem}.gear-loading-pack{width:32px;height:40px;margin:0 auto var(--space-md);background:linear-gradient(to bottom,var(--sage) 60%,var(--sage-deep) 100%);border-radius:6px 6px 4px 4px;position:relative;animation:gear-pack-bob 1.2s ease-in-out infinite}.gear-loading-pack:before{content:"";position:absolute;top:-4px;left:4px;right:4px;height:8px;background:var(--sage-deep);border-radius:4px 4px 0 0;animation:gear-pack-flap 1.2s ease-in-out infinite;transform-origin:left center}@keyframes gear-pack-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes gear-pack-flap{0%,to{transform:rotate(0)}30%{transform:rotate(-8deg)}60%{transform:rotate(3deg)}}@media(max-width:600px){.gear-modal{width:100%;max-height:90vh;border-radius:var(--radius-md) var(--radius-md) 0 0;margin-top:auto}.gear-modal-header{padding:var(--space-md) var(--space-md)}.gear-modal-body{padding:var(--space-sm) var(--space-md) var(--space-lg)}.gear-add-form{flex-wrap:wrap}.gear-add-input{flex:1 1 100%}.gear-item--editing{flex-wrap:wrap}.gear-item-edit-name{flex:1 1 100%}}.itinerary-modal{max-width:520px;width:94%;max-height:85vh;display:flex;flex-direction:column;text-align:left;padding:var(--space-lg) var(--space-xl) var(--space-md)}.itinerary-header{text-align:center;flex-shrink:0}.itinerary-header-icon{margin-bottom:var(--space-sm)}.itinerary-header .modal-title{margin-bottom:var(--space-xs)}.itinerary-body{flex:1;overflow-y:auto;min-height:0;padding:var(--space-sm) var(--space-xs);margin:0 calc(var(--space-xs) * -1)}.itinerary-body::-webkit-scrollbar{width:6px}.itinerary-body::-webkit-scrollbar-track{background:transparent}.itinerary-body::-webkit-scrollbar-thumb{background:var(--tan-deep);border-radius:3px}.itinerary-loading{display:flex;justify-content:center;gap:var(--space-sm);padding:var(--space-xl) 0}.itinerary-loading-dot{width:8px;height:8px;border-radius:50%;background:var(--tan-deep);animation:itinerary-bounce 1.2s ease infinite}.itinerary-loading-dot:nth-child(2){animation-delay:.15s}.itinerary-loading-dot:nth-child(3){animation-delay:.3s}@keyframes itinerary-bounce{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1.1)}}.itinerary-empty{display:flex;flex-direction:column;align-items:center;padding:var(--space-xl) var(--space-md);text-align:center}.itinerary-empty-icon{opacity:.5;margin-bottom:var(--space-md)}.itinerary-empty-text{font-family:var(--font-body);font-style:italic;font-size:.95rem;color:var(--charcoal-light);line-height:1.6;max-width:280px}.itinerary-timeline{display:flex;flex-direction:column;gap:var(--space-md)}.itinerary-day{position:relative}.itinerary-day-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm);padding-bottom:var(--space-xs);border-bottom:1px solid rgba(168,139,91,.2)}.itinerary-day-date{font-family:var(--font-display);font-size:.85rem;font-weight:700;color:var(--charcoal);letter-spacing:.03em}.itinerary-day-count{font-size:.75rem;color:var(--charcoal-light);opacity:.7}.itinerary-event{position:relative;margin-left:var(--space-sm);border-left:2px solid var(--tan-deep);padding-left:0;margin-bottom:2px;transition:background .2s ease;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.itinerary-event:last-child{margin-bottom:0}.itinerary-event:hover{background:#a88b5b0f}.itinerary-event.expanded{background:#a88b5b14;border-left-color:var(--sage-deep)}.itinerary-event-main{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-sm) var(--space-sm) var(--space-md);min-height:44px}.itinerary-event-time-col{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0;min-width:72px}.itinerary-event-dot{width:7px;height:7px;border-radius:50%;background:var(--sage);border:1.5px solid var(--sage-deep);position:absolute;left:-5px}.itinerary-event-time{font-size:.78rem;font-weight:600;color:var(--charcoal-light);font-variant-numeric:tabular-nums}.itinerary-event-content{flex:1;min-width:0}.itinerary-event-title{font-size:.92rem;font-weight:600;color:var(--charcoal);display:block;line-height:1.3}.itinerary-event-expand-hint{font-size:.72rem;color:var(--charcoal-light);opacity:.5;font-style:italic}.itinerary-event-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity .2s ease}.itinerary-event:hover .itinerary-event-actions{opacity:1}.itinerary-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:#0000000a;color:var(--charcoal-light);transition:all .2s ease}.itinerary-action-btn:hover{background:#00000014;color:var(--charcoal)}.itinerary-action-btn--danger:hover{background:#e85d3a1f;color:var(--flame)}.itinerary-action-btn:disabled{opacity:.4;cursor:not-allowed}.itinerary-event-details{padding:0 var(--space-sm) var(--space-sm) calc(var(--space-md) + 72px + var(--space-sm));animation:fade-in .2s ease}.itinerary-event-desc{font-size:.88rem;color:var(--charcoal);line-height:1.5;margin-bottom:var(--space-xs)}.itinerary-event-notes{font-size:.82rem;color:var(--charcoal-light);line-height:1.5;display:flex;align-items:flex-start;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:#a88b5b14;border-radius:var(--radius-sm)}.itinerary-notes-icon{flex-shrink:0;margin-top:2px;opacity:.6}.itinerary-form{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-xs) 0}.itinerary-form-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--charcoal);margin-bottom:var(--space-xs)}.itinerary-textarea{resize:vertical;min-height:48px;max-height:120px;font-family:var(--font-body);line-height:1.4}.itinerary-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid rgba(168,139,91,.15);flex-shrink:0}.itinerary-add-btn{display:flex;align-items:center;gap:var(--space-xs);margin-right:auto}.assign-modal-overlay{z-index:100}.assign-modal{background:linear-gradient(155deg,#faf5ebfa,#f0e8d6fa 40%,#ede4d0fa);border:1px solid rgba(168,139,91,.3);border-radius:var(--radius-lg);max-width:620px;width:94%;height:80vh;display:flex;flex-direction:column;animation:scale-in .3s ease;box-shadow:0 24px 80px #00000073,0 0 0 1px #fff8e71a,inset 0 1px #ffffff80;position:relative;overflow:hidden}.assign-modal:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 15% 20%,rgba(168,139,91,.07) 0%,transparent 50%),radial-gradient(ellipse at 85% 80%,rgba(168,139,91,.05) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(139,120,80,.03) 0%,transparent 70%);pointer-events:none;z-index:0}.assign-modal:after{content:"";position:absolute;inset:6px;border:1px dashed rgba(168,139,91,.15);border-radius:calc(var(--radius-lg) - 4px);pointer-events:none;z-index:0}.assign-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid rgba(168,139,91,.15);position:relative;z-index:1}.assign-modal-header-left{display:flex;align-items:center;gap:var(--space-md)}.assign-modal-icon{flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.assign-modal-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--charcoal);letter-spacing:.02em}.assign-modal-subtitle{font-family:var(--font-body);font-size:.8rem;color:var(--charcoal-light);font-style:italic;margin-top:2px}.assign-modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#0000000a;color:var(--charcoal-light);transition:all .2s ease;flex-shrink:0}.assign-modal-close:hover{background:#00000014;color:var(--charcoal)}.assign-tabs{display:flex;gap:4px;padding:var(--space-sm) var(--space-xl) var(--space-sm);position:relative;z-index:1}.assign-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-xs);font-family:var(--font-body);font-size:.85rem;font-weight:600;padding:10px 16px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;border:1px solid rgba(168,139,91,.2);border-bottom:none;background:#fff3;color:var(--charcoal-light);cursor:pointer;transition:all .2s ease}.assign-tab:hover{background:#fff6;color:var(--charcoal)}.assign-tab--active{background:#ffffff80;border-color:#a88b5b4d;color:var(--charcoal);box-shadow:0 -2px 8px #0000000a}.assign-tab-icon{font-size:1rem;line-height:1}.assign-modal-body{flex:1;overflow-y:auto;padding:var(--space-md) var(--space-xl) var(--space-xl);position:relative;z-index:1}.assign-modal-body::-webkit-scrollbar{width:6px}.assign-modal-body::-webkit-scrollbar-track{background:transparent}.assign-modal-body::-webkit-scrollbar-thumb{background:#a88b5b33;border-radius:3px}.assign-modal-body::-webkit-scrollbar-thumb:hover{background:#a88b5b59}.assign-unassigned{background:#e85d3a0d;border:1px dashed rgba(232,93,58,.2);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md)}.assign-unassigned-label{font-family:var(--font-body);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--charcoal-light);opacity:.7;display:block;margin-bottom:var(--space-xs)}.assign-unassigned-list{display:flex;flex-wrap:wrap;gap:var(--space-md)}.assign-unassigned-member{display:flex;flex-direction:column;align-items:center;gap:2px}.assign-unassigned-name{font-family:var(--font-body);font-size:.68rem;color:var(--charcoal-light);max-width:56px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.assign-card{background:#ffffff73;border:1px solid rgba(168,139,91,.2);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-sm);position:relative;transition:all .2s ease;box-shadow:0 2px 8px #0000000a}.assign-card:hover{box-shadow:0 4px 16px #00000014;border-color:#a88b5b4d}.assign-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.assign-card-name{font-family:var(--font-body);font-size:.95rem;font-weight:700;color:var(--charcoal)}.assign-card-edit-name{flex:1;min-width:0;font-family:var(--font-body);font-size:.9rem;padding:4px 8px;border:1px solid var(--tan-deep);border-radius:4px;background:#ffffffb3;color:var(--charcoal)}.assign-card-edit-name:focus{border-color:var(--lavender-deep);box-shadow:0 0 0 2px #b8a5cc33}.assign-card-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity .2s ease}.assign-card:hover .assign-card-actions{opacity:1}.assign-card-header:has(.assign-card-edit-name) .assign-card-actions{opacity:1}.assign-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:#0000000a;color:var(--charcoal-light);transition:all .2s ease}.assign-action-btn:hover{background:#00000014;color:var(--charcoal)}.assign-action-btn--danger:hover{background:#e85d3a1f;color:var(--flame)}.assign-save-btn,.assign-cancel-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:.85rem;font-weight:700;cursor:pointer;padding:0;transition:all .15s ease}.assign-save-btn{background:var(--sage-deep);color:#fff}.assign-save-btn:hover{background:var(--sage-dark)}.assign-cancel-btn{background:#0000000f;color:var(--charcoal-light)}.assign-cancel-btn:hover{background:#0000001a}.assign-card-owner{font-family:var(--font-body);font-size:.72rem;color:var(--charcoal-light);opacity:.7;font-style:italic}.assign-card-occupancy{display:flex;align-items:center;gap:var(--space-sm);margin:var(--space-sm) 0}.assign-card-spots{font-family:var(--font-body);font-size:.78rem;font-weight:600;color:var(--charcoal-light);white-space:nowrap}.assign-occupancy-bar{flex:1;height:6px;background:var(--tan);border-radius:3px;overflow:hidden}.assign-occupancy-fill{height:100%;background:linear-gradient(90deg,var(--sage-deep),var(--sage));border-radius:3px;transition:width .4s ease}.assign-card-edit-occupancy{display:flex;align-items:center;gap:var(--space-sm);width:100%}.assign-card-edit-label,.assign-create-label{font-family:var(--font-body);font-size:.8rem;font-weight:600;color:var(--charcoal-light);white-space:nowrap}.assign-occupancy-stepper{display:flex;align-items:center;gap:2px}.assign-qty-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;background:#0000000d;color:var(--charcoal);font-size:.9rem;font-weight:700;cursor:pointer;padding:0;transition:background .15s ease;line-height:1}.assign-qty-btn:hover:not(:disabled){background:#0000001a}.assign-qty-btn:disabled{opacity:.3;cursor:not-allowed}.assign-qty-value{font-family:var(--font-body);font-size:.85rem;font-weight:600;color:var(--charcoal);min-width:24px;text-align:center}.assign-card-members{display:flex;flex-direction:column;gap:4px;margin-bottom:var(--space-sm)}.assign-member{display:flex;align-items:center;gap:8px;padding:3px 6px;border-radius:var(--radius-sm);transition:background .15s ease}.assign-member:hover{background:#00000005}.assign-member:hover .assign-member-remove{opacity:1}.assign-mini-avatar{flex-shrink:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.15))}.assign-member-name{font-family:var(--font-body);font-size:.82rem;color:var(--charcoal);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.assign-member-badge{font-family:var(--font-body);font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--tan-dark);background:#a88b5b1a;padding:1px 6px;border-radius:8px}.assign-member-remove{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:4px;background:none;color:var(--charcoal-light);cursor:pointer;transition:all .15s ease;padding:0;opacity:0;flex-shrink:0}.assign-member-remove:hover{background:#e85d3a1a;color:var(--flame)}.assign-card-footer{display:flex;justify-content:flex-end;gap:var(--space-sm)}.assign-join-btn{font-family:var(--font-body);font-size:.8rem;font-weight:600;padding:5px 16px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--sage-deep),var(--sage-dark));color:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #5a7a5633}.assign-join-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #5a7a564d}.assign-leave-btn{font-family:var(--font-body);font-size:.8rem;font-weight:600;padding:5px 16px;border-radius:var(--radius-sm);background:transparent;color:var(--charcoal-light);border:1px solid var(--tan-deep);cursor:pointer;transition:all .2s ease}.assign-leave-btn:hover{background:#0000000a;border-color:var(--charcoal-light)}.assign-full-badge{font-family:var(--font-body);font-size:.75rem;font-weight:600;color:var(--charcoal-light);opacity:.6;font-style:italic}.assign-create-form{background:#fff6;border:1px dashed rgba(168,139,91,.3);border-radius:var(--radius-md);padding:var(--space-md);margin-top:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-sm);animation:gear-section-expand .2s ease}.assign-create-title{font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--charcoal)}.assign-create-input{width:100%;font-family:var(--font-body);font-size:.88rem;padding:8px 12px;border:1px solid var(--tan-deep);border-radius:var(--radius-sm);background:#fff9;color:var(--charcoal);transition:all .2s ease}.assign-create-input:focus{border-color:var(--lavender-deep);box-shadow:0 0 0 2px #b8a5cc33}.assign-create-input::placeholder{color:var(--tan-deep);font-style:italic}.assign-create-occupancy{display:flex;align-items:center;gap:var(--space-sm)}.assign-create-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-xs)}.assign-modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);border-top:1px solid rgba(168,139,91,.15);position:relative;z-index:1;flex-shrink:0}.assign-create-btn{display:flex;align-items:center;gap:var(--space-xs);margin-right:auto}.assign-empty{display:flex;flex-direction:column;align-items:center;padding:var(--space-xl) var(--space-md);text-align:center}.assign-empty-icon{opacity:.5;margin-bottom:var(--space-md)}.assign-empty-text{font-family:var(--font-body);font-style:italic;font-size:.95rem;color:var(--charcoal-light);line-height:1.6;max-width:280px}.assign-loading{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--charcoal-light);font-style:italic;font-size:.9rem}.assign-loading-tent{width:32px;height:32px;margin:0 auto var(--space-md);position:relative;animation:gear-pack-bob 1.2s ease-in-out infinite}.assign-loading-tent:before{content:"";position:absolute;left:50%;bottom:0;transform:translate(-50%);width:0;height:0;border-left:16px solid transparent;border-right:16px solid transparent;border-bottom:28px solid var(--rose)}.assign-loading-tent:after{content:"";position:absolute;left:50%;bottom:0;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:12px solid var(--rose-deep)}.assign-error{font-family:var(--font-body);font-size:.82rem;color:var(--flame);background:#e85d3a14;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-sm);border:1px solid rgba(232,93,58,.15)}.assign-add-member-btn{font-family:var(--font-body);font-size:.78rem;padding:4px 10px;border-radius:var(--radius-sm);border:1px solid rgba(168,139,91,.3);background:#a88b5b14;color:var(--tan-deep);cursor:pointer;transition:all .15s ease}.assign-add-member-btn:hover{background:#a88b5b2e}.assign-add-member-panel{background:#a88b5b14;border-top:1px solid rgba(168,139,91,.2);margin:var(--space-sm) calc(-1 * var(--space-md)) calc(-1 * var(--space-md));padding:var(--space-sm) var(--space-md) var(--space-md);border-radius:0 0 var(--radius-md) var(--radius-md)}.assign-add-member-heading{font-family:var(--font-body);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--tan-deep);display:block;margin-bottom:var(--space-xs)}.assign-add-member-list{display:flex;flex-direction:column;gap:2px}.assign-add-member-option{display:flex;align-items:center;gap:var(--space-xs);padding:5px var(--space-sm);border:none;background:transparent;cursor:pointer;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.82rem;color:var(--text-primary);transition:background .15s ease;text-align:left}.assign-add-member-option .assign-mini-avatar{width:22px;height:22px;flex-shrink:0}.assign-add-member-option:hover:not(:disabled){background:#a88b5b26}.assign-add-member-option--taken{opacity:.4;cursor:not-allowed;filter:grayscale(.6)}.assign-add-member-name{flex:1}.assign-add-member-group{font-size:.72rem;font-style:italic;color:var(--charcoal-light)}.assign-add-member-empty{font-family:var(--font-body);font-size:.78rem;color:var(--text-secondary);font-style:italic;padding:var(--space-xs) var(--space-sm)}.assign-add-error{font-family:var(--font-body);font-size:.78rem;color:var(--flame);background:#e85d3a1a;padding:4px var(--space-sm);border-radius:var(--radius-sm);margin-bottom:var(--space-xs);border:1px solid rgba(232,93,58,.15)}@media(max-width:600px){.assign-modal{width:100%;max-height:90vh;border-radius:var(--radius-md) var(--radius-md) 0 0;margin-top:auto}.assign-modal-header{padding:var(--space-md) var(--space-md)}.assign-modal-body{padding:var(--space-sm) var(--space-md) var(--space-lg)}.assign-modal-footer{padding:var(--space-sm) var(--space-md)}.assign-tabs{padding:var(--space-sm) var(--space-md) var(--space-sm)}}.plan-page{min-height:100vh;position:relative;overflow:hidden}.plan-header{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-xl);background:#0a081466;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,248,231,.06)}.plan-back{display:flex;align-items:center;gap:var(--space-xs);font-family:var(--font-body);font-size:.85rem;font-weight:600;color:var(--parchment);background:none;border:none;cursor:pointer;padding:6px 12px;border-radius:var(--radius-xl);transition:all .3s ease;opacity:.7}.plan-back:hover{opacity:1;background:#ffffff0d}.plan-header-center{display:flex;align-items:center;gap:var(--space-sm)}.plan-header-icon{filter:drop-shadow(0 0 6px rgba(244,164,96,.3))}.plan-header-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--parchment);letter-spacing:.04em}.campsite-scene{position:relative;width:100%;height:100vh;display:flex;align-items:center;justify-content:center;padding-top:34vh}.campsite-center{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.campsite-invite-ghost{display:flex;flex-direction:column;align-items:center;gap:4px;margin-top:var(--space-xl);background:none;border:none;cursor:pointer;padding:0;opacity:.6;transition:opacity .3s ease,transform .3s ease}.campsite-invite-ghost:hover{opacity:1;transform:scale(1.08)}.campsite-invite-ghost:hover .invite-ghost-figure{filter:drop-shadow(0 0 12px rgba(255,248,231,.3))}.invite-ghost-figure{animation:gentle-bob 4s ease-in-out infinite;transition:filter .3s ease}.invite-ghost-label{font-family:var(--font-body);font-size:.65rem;font-weight:600;color:#fff8e766;background:#0003;padding:2px 8px;border-radius:8px;transition:color .3s ease}.campsite-invite-ghost:hover .invite-ghost-label{color:#fff8e7cc}.campfire-circle{position:absolute;width:0;height:0;z-index:15}.plan-header-user{display:flex;align-items:center;gap:var(--space-md)}.plan-user-btn{display:flex;align-items:center;gap:var(--space-sm);background:#ffffff0f;border:1px solid rgba(255,248,231,.12);border-radius:var(--radius-xl);padding:4px 14px 4px 4px;cursor:pointer;transition:all .3s ease}.plan-user-btn:hover{background:#ffffff1f;border-color:#fff8e740}.plan-user-avatar{flex-shrink:0}.plan-user-name{font-size:.85rem;font-family:var(--font-body);color:var(--lavender-light)}.plan-logout{font-size:.8rem;font-weight:600;font-family:var(--font-body);color:var(--rose);background:#e8b4b81a;border:1px solid rgba(232,180,184,.25);padding:6px 14px;border-radius:var(--radius-xl);cursor:pointer;transition:all .3s ease}.plan-logout:hover{background:#e8b4b833;border-color:#e8b4b866}.celestial-toggle{position:fixed;top:10%;right:33%;z-index:45;background:none;border:none;cursor:pointer;padding:0;opacity:.8;transition:opacity .3s ease,transform .3s ease,filter .3s ease;filter:drop-shadow(0 0 12px rgba(200,208,216,.15))}.celestial-toggle:hover{opacity:1;transform:scale(1.1);filter:drop-shadow(0 0 20px rgba(240,208,96,.3))}.campsite-join-btn{display:flex;flex-direction:column;align-items:center;gap:6px;margin-top:var(--space-xl);background:none;border:none;cursor:pointer;padding:0;transition:opacity .3s ease,transform .3s ease}.campsite-join-btn:hover:not(:disabled){transform:scale(1.1)}.campsite-join-btn:disabled{opacity:.5;cursor:not-allowed}.join-ghost-figure{animation:gentle-bob 3s ease-in-out infinite;filter:drop-shadow(0 0 8px rgba(139,195,128,.2));transition:filter .3s ease}.campsite-join-btn:hover .join-ghost-figure{filter:drop-shadow(0 0 16px rgba(139,195,128,.4))}.join-label{font-family:var(--font-body);font-size:.75rem;font-weight:700;color:var(--sage);background:#0000004d;padding:3px 12px;border-radius:10px;letter-spacing:.03em;transition:color .3s ease,background .3s ease}.campsite-join-btn:hover .join-label{color:var(--parchment);background:#5a7a5680}.plan-manage-btn{display:flex;align-items:center;gap:var(--space-xs);font-family:var(--font-body);font-size:.85rem;font-weight:600;color:var(--parchment);background:#ffffff14;border:1px solid rgba(255,248,231,.15);padding:6px 14px;border-radius:var(--radius-xl);cursor:pointer;transition:all .3s ease}.plan-manage-btn:hover{background:#ffffff26;border-color:#fff8e74d}.manage-plan-modal{text-align:left}.manage-plan-setting{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);padding:var(--space-md) 0}.manage-plan-setting-info{display:flex;flex-direction:column;gap:4px}.manage-plan-setting-label{font-family:var(--font-body);font-weight:700;font-size:.95rem;color:var(--charcoal)}.manage-plan-setting-desc{font-family:var(--font-body);font-size:.85rem;color:var(--charcoal-light);font-style:italic}.manage-plan-name-input{flex:1;font-family:var(--font-body);font-size:.9rem;padding:6px 10px;border:1px solid var(--tan-deep);border-radius:var(--radius-md);background:var(--parchment);color:var(--charcoal)}.manage-plan-name-input:focus{outline:none;border-color:var(--sage-deep);box-shadow:0 0 0 2px #5a7a5626}.manage-plan-save-btn{padding:6px 14px!important;font-size:.85rem!important;white-space:nowrap}.visibility-toggle{display:flex;align-items:center;gap:var(--space-sm);background:none;border:none;cursor:pointer;padding:0;flex-shrink:0}.visibility-toggle:disabled{opacity:.5;cursor:not-allowed}.visibility-toggle-track{position:relative;width:44px;height:24px;border-radius:12px;background:var(--charcoal-light);transition:background .3s ease}.visibility-toggle.public .visibility-toggle-track{background:var(--sage-deep)}.visibility-toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .3s ease;box-shadow:0 1px 3px #0003}.visibility-toggle.public .visibility-toggle-thumb{transform:translate(20px)}.visibility-toggle-label{font-family:var(--font-body);font-weight:600;font-size:.85rem;color:var(--charcoal);min-width:50px}.campsite-loading{text-align:center;color:var(--lavender-light);opacity:.7;font-style:italic;animation:fade-in .3s ease}.campsite-loading-flame{width:24px;height:36px;margin:0 auto var(--space-md);background:radial-gradient(ellipse at bottom,var(--ember) 0%,transparent 70%);border-radius:50%/60% 60% 40% 40%;animation:campfire-dance .8s ease-in-out infinite}.account-page{min-height:100vh;position:relative}.account-content{position:relative;z-index:10;min-height:100vh;display:flex;flex-direction:column}.account-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-xl);background:#0a08144d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,248,231,.08)}.account-back{display:flex;align-items:center;gap:var(--space-xs);font-family:var(--font-body);font-size:.85rem;font-weight:600;color:var(--parchment);background:none;border:none;cursor:pointer;padding:6px 12px;border-radius:var(--radius-xl);transition:all .3s ease;opacity:.7}.account-back:hover{opacity:1;background:#ffffff0d}.account-header-center{display:flex;align-items:center;gap:var(--space-sm)}.account-header-icon{filter:drop-shadow(0 0 6px rgba(244,164,96,.3))}.account-header-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--parchment);letter-spacing:.04em}.account-header-user{display:flex;align-items:center;gap:var(--space-md)}.account-user-btn{display:flex;align-items:center;gap:var(--space-sm);background:#ffffff0f;border:1px solid rgba(255,248,231,.12);border-radius:var(--radius-xl);padding:4px 14px 4px 4px}.account-user-avatar{flex-shrink:0}.account-user-name{font-size:.85rem;font-family:var(--font-body);color:var(--lavender-light)}.account-logout{font-size:.8rem;font-weight:600;color:var(--rose);background:#e8b4b81a;border:1px solid rgba(232,180,184,.25);padding:6px 14px;border-radius:var(--radius-xl);cursor:pointer;transition:all .3s ease}.account-logout:hover{background:#e8b4b833;border-color:#e8b4b866}.account-card-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-xl)}.account-card{position:relative;background:#faf5ebf0;border:1px solid rgba(168,139,91,.25);border-radius:var(--radius-lg);padding:var(--space-2xl) var(--space-xl);max-width:440px;width:100%;text-align:center;box-shadow:0 12px 40px #0003;animation:fade-in-up .5s ease backwards}.account-close{position:absolute;top:var(--space-md);right:var(--space-md);background:none;border:none;cursor:pointer;color:var(--charcoal-light);padding:6px;border-radius:50%;transition:all .2s ease;opacity:.5}.account-close:hover{opacity:1;background:#0000000f}.account-avatar{margin-bottom:var(--space-md)}.account-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--charcoal);margin-bottom:var(--space-lg)}.account-form{display:flex;flex-direction:column;gap:var(--space-md);text-align:left}.account-field{display:flex;flex-direction:column;gap:4px}.account-label{font-family:var(--font-body);font-size:.8rem;font-weight:700;color:var(--charcoal-light);text-transform:uppercase;letter-spacing:.06em}.account-input{width:100%;padding:12px 16px;font-size:1rem;font-family:var(--font-body);border:2px solid var(--tan-deep);border-radius:var(--radius-md);background:#fff9;color:var(--charcoal);transition:border-color .3s ease,box-shadow .3s ease}.account-input:focus{border-color:var(--sage-deep);box-shadow:0 0 0 3px #8fb08a40;outline:none}.account-input::placeholder{color:var(--tan-deep);font-style:italic}.account-input--readonly{background:#0000000a;color:var(--charcoal-light);cursor:default;border-color:#a88b5b26}.account-input--readonly:focus{border-color:#a88b5b26;box-shadow:none}.account-error{font-size:.85rem;color:var(--flame)}.account-save{padding:12px 24px;font-size:.95rem;font-weight:700;font-family:var(--font-body);color:#fff;background:linear-gradient(135deg,var(--sage-deep),var(--sage-dark));border:none;border-radius:var(--radius-md);cursor:pointer;box-shadow:0 4px 12px #5a7a564d;transition:all .3s ease;margin-top:var(--space-sm)}.account-save:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #5a7a5666}.account-save:disabled{opacity:.5;cursor:not-allowed}.account-meta{margin-top:var(--space-lg);font-size:.8rem;font-style:italic;color:var(--charcoal-light);opacity:.6}
