*{box-sizing:border-box}html,body{margin:0;font-family:DM Sans,sans-serif;background-color:#0f0f10;color:#eaeaea;height:100%}header{background-color:#1a1a1a;box-shadow:0 0 8px #0009;display:flex;justify-content:center;color:#fff;height:100px;align-items:center;border-bottom:1px solid #2a2a2a}main{padding:50px 30px 10px;background-color:#0f0f10;border-radius:8px;min-height:100vh}li{margin-bottom:10px;line-height:1.6;border-radius:6px}textarea,input{font-family:DM Sans,sans-serif}.add-item-form{display:flex;justify-content:center;align-items:center;gap:12px;height:48px;margin-top:20px;background:linear-gradient(135deg,#1a1f2e,#2a3441);border-radius:14px;padding:6px;box-shadow:0 6px 24px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:70%;margin-left:auto;margin-right:auto}.add-item-form>input{border-radius:10px;border:2px solid #3a4a5c;padding:10px 14px;box-shadow:0 3px 8px #0003;flex-grow:1;min-width:250px;max-width:400px;background:linear-gradient(135deg,#1e1e1e,#252525);color:#eaeaea;transition:all .3s ease;font-size:.95rem;font-weight:500}.add-item-form>input:hover{border-color:#5170ff;background:linear-gradient(135deg,#252525,#2a2a2a);box-shadow:0 6px 16px #5170ff26;transform:translateY(-1px)}.add-item-form>input:focus{border-color:#5170ff;box-shadow:0 0 0 4px #5170ff33,0 8px 20px #5170ff26;outline:none;background:linear-gradient(135deg,#252525,#2a2a2a);transform:translateY(-2px)}.add-item-form>input::placeholder{color:#888;font-style:italic;font-weight:400}.add-item-form>button{font-family:DM Sans,sans-serif;border-radius:10px;border:none;background:linear-gradient(135deg,#5170ff,#6b7fff);color:#fff;width:120px;font-size:.9rem;font-weight:600;padding:10px 0;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #5170ff4d;position:relative;overflow:hidden}.add-item-form>button:before{content:"+";margin-right:8px;font-size:1.1rem;font-weight:700}.add-item-form>button:hover{background:linear-gradient(135deg,#3a58e5,#5a9eff);box-shadow:0 8px 25px #5170ff66;transform:translateY(-2px)}.add-item-form>button:active{background:linear-gradient(135deg,#2f49c3,#4a7ce8);transform:scale(.98);box-shadow:0 4px 15px #2f49c366}.image-attach-btn{font-family:DM Sans,sans-serif;border-radius:10px;border:2px solid #3a4a5c;background:linear-gradient(135deg,#2a2a2a,#333);color:#fff;width:48px;height:48px;font-size:1.1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 3px 8px #0003;display:flex;align-items:center;justify-content:center;padding:0;font-weight:600}.image-attach-btn:hover{background:linear-gradient(135deg,#333,#3a3a3a);border-color:#5170ff;box-shadow:0 6px 16px #5170ff26;transform:translateY(-2px)}.image-attach-btn:active{transform:scale(.95);background:linear-gradient(135deg,#1a1a1a,#252525)}.image-selected-info{display:block;color:#8c8;font-size:12px;margin-top:8px;font-weight:500}.purpose-container{margin-bottom:50px;display:flex;flex-direction:column;align-items:center;text-align:center;background:linear-gradient(135deg,#1a1f2e,#2a3441);border-radius:16px;padding:24px;box-shadow:0 8px 32px #0000004d,0 0 0 1px #5170ff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #3a4a5c;max-width:70%;margin-left:auto;margin-right:auto}.purpose-label{display:block;font-weight:700;margin-top:0;margin-bottom:10px;font-size:1.2rem;color:#eaeaea;background:linear-gradient(135deg,#eaeaea,#b0b0b0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.purpose-info{display:block;margin-bottom:18px;font-size:.95rem;color:#b0b0b0;line-height:1.4}.purpose-text{min-width:500px;width:65%;min-height:150px;padding:16px 20px;border:2px solid #3a4a5c;border-radius:14px;font-size:.95rem;line-height:1.5;resize:none;transition:all .3s ease;background:linear-gradient(135deg,#1e1e1e,#252525);color:#eaeaea;box-shadow:0 6px 20px #0003;font-family:inherit;font-weight:500}.purpose-text:hover{border-color:#5170ff;background:linear-gradient(135deg,#252525,#2a2a2a);box-shadow:0 12px 32px #5170ff26;transform:translateY(-2px)}.purpose-text:focus{border-color:#5170ff;box-shadow:0 0 0 4px #5170ff33,0 12px 32px #5170ff26;outline:none;background:linear-gradient(135deg,#252525,#2a2a2a);transform:translateY(-2px);animation:textareaFocus .3s ease-out}@keyframes textareaFocus{0%{transform:scale(1) translateY(0)}50%{transform:scale(1.01) translateY(-1px)}to{transform:scale(1) translateY(-1px)}}.packed-list-section{max-width:55%;margin:0 auto 50px;text-align:left;background:linear-gradient(135deg,#1a1f2e,#2a3441);border-radius:16px;padding:24px;box-shadow:0 8px 32px #0000004d,0 0 0 1px #5170ff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #3a4a5c}.packed-list-section h2{color:#eaeaea;font-size:1.3rem;font-weight:700;margin-bottom:18px;text-align:left;background:linear-gradient(135deg,#eaeaea,#b0b0b0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;border-bottom:2px solid #3a4a5c;padding-bottom:12px}.items-list{margin-bottom:0;list-style:none;padding:0}.items-list li{background:linear-gradient(135deg,#2a3441,#3a4a5c);color:#eaeaea;line-height:1.5;padding:12px 16px;margin-bottom:10px;border-radius:10px;border:1px solid #3a4a5c;box-shadow:0 3px 8px #0003;transition:all .3s ease;font-weight:500;position:relative;font-size:.95rem}.items-list li:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0000004d;border-color:#5170ff}.items-list li:before{content:"📦";margin-right:12px;font-size:1.1rem}.items-list li:last-child{margin-bottom:0}.recommend-items-container{display:flex;justify-content:center;margin-top:20px;position:relative}.recommend-items-container:before{content:"↓";position:absolute;top:-40px;left:50%;transform:translate(-50%);color:#5170ff;font-size:1.5rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3);z-index:10}.recommend-items-box{display:flex;align-items:center;border-radius:12px;background:linear-gradient(135deg,#1a1f2e,#2a3441);padding:20px 30px;margin-bottom:25px;box-shadow:0 4px 16px #5170ff26;position:relative;max-width:600px;width:50%}.recommend-items-box h3{font-size:1.125rem;font-weight:500;line-height:24px;color:#eaeaea}.recommend-items-box p{color:#aaa;font-size:.875rem;line-height:20px}.recommend-items-box button{border:none;border-radius:8px;background:linear-gradient(135deg,#5170ff,#6b7fff);box-shadow:0 6px 20px #5170ff66;color:#fafaf8;padding:12px 25px;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:600;cursor:pointer;margin-left:20px;transition:all .3s ease;position:relative;overflow:visible;min-width:180px;white-space:normal;text-align:center;line-height:1.2;display:flex;align-items:center;justify-content:center;flex-direction:column}.recommend-items-box button:hover{background:linear-gradient(135deg,#3a58e5,#5a9eff);box-shadow:0 8px 25px #5170ff80;transform:translateY(-2px)}.recommend-items-box button:active{background:linear-gradient(135deg,#2f49c3,#4a7ce8);transform:scale(.98);box-shadow:0 4px 15px #2f49c366}.suggested-recipe-container{color:#eaeaea;line-height:1.4;font-size:1rem;font-weight:400}@media(max-width:600px){main{padding:20px 15px}.add-item-form{flex-direction:column;height:auto;padding:12px;gap:10px;margin:16px 0;max-width:100%}.add-item-form>input{max-width:100%;width:100%;min-width:unset}.add-item-form>button{width:100%;margin-top:0;padding:14px 20px}.image-attach-btn{width:100%;height:48px;order:-1}.purpose-container{padding:20px 16px;margin:16px 0;max-width:100%}.purpose-text{min-width:unset;width:100%;font-size:.9rem;min-height:120px}.recommend-items-box{flex-direction:column;padding:24px 20px;gap:20px;width:100%;max-width:100%}.recommend-items-box button{width:100%;margin-left:0;padding:16px 24px}.packed-list-section{max-width:100%;margin:20px 0;padding:24px 20px;border-radius:16px}.packed-list-section h2{font-size:1.2rem;margin-bottom:20px}.items-list li{padding:14px 16px;font-size:.95rem;margin-bottom:10px}}.saved-entries-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.saved-entries-modal{background-color:#1e1e1e;border-radius:12px;width:100%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000080}.saved-entries-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #333}.saved-entries-header h2{color:#eaeaea;margin:0}.close-btn{background:none;border:none;color:#eaeaea;font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#fff}.saved-entries-content{display:flex;flex:1;overflow:hidden}.trip-summary{color:#bbb;font-size:14px;margin:8px 0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.details-header h3{color:#eaeaea;margin:0}.trip-info,.packed-items,.ai-recommendations{margin-bottom:25px}.trip-info h4,.packed-items h4,.ai-recommendations h4{color:#eaeaea;margin:0 0 10px;font-size:16px}.no-recommendations{color:#888;text-align:center;padding:40px 20px;font-style:italic}@media(max-width:768px){.add-item-form{max-width:100%;margin:20px 16px 50px}.purpose-container{padding:24px 20px;margin:20px 16px 50px;max-width:calc(100% - 32px)}.purpose-text{min-width:unset;width:100%;font-size:.95rem}.recommend-items-box{flex-direction:column;padding:24px 20px;gap:20px;width:100%;max-width:100%}.recommend-items-box button{width:100%;margin-left:0;padding:16px 24px}.packed-list-section{max-width:100%;margin:20px 16px;padding:24px 20px;border-radius:16px}.packed-list-section h2{font-size:1.3rem;margin-bottom:20px}.items-list li{padding:14px 16px;font-size:.95rem;margin-bottom:10px}}.landing-page{min-height:100vh;background:#0f0f10;color:#eaeaea;display:flex;flex-direction:column;overflow-x:hidden}.hero-section{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;overflow:hidden}.hero-background{position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(81,112,255,.1) 0%,transparent 70%);pointer-events:none}.floating-elements{position:absolute;width:100%;height:100%;pointer-events:none}.floating-element{position:absolute;font-size:2rem;opacity:.3;animation:float 6s ease-in-out infinite}.floating-element.element-1{top:20%;left:10%;animation-delay:0s}.floating-element.element-2{top:30%;right:15%;animation-delay:1s}.floating-element.element-3{top:60%;left:20%;animation-delay:2s}.floating-element.element-4{top:70%;right:25%;animation-delay:3s}.floating-element.element-5{top:40%;left:70%;animation-delay:4s}.floating-element.element-6{top:80%;right:10%;animation-delay:5s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(5deg)}}.hero-content{position:relative;z-index:2;max-width:1000px;margin:0 auto;width:100%}.hero-badge{display:inline-flex;align-items:center;background:#5170ff1a;border:1px solid rgba(81,112,255,.3);border-radius:50px;padding:8px 20px;margin-bottom:24px;font-size:.9rem;font-weight:500;color:#8b5cf6}.hero-title{font-size:4rem;font-weight:800;margin:0 0 24px;background:linear-gradient(135deg,#5170ff,#8b5cf6,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1}.hero-description{font-size:1.3rem;color:#b5b5b5;max-width:800px;margin:0 auto 40px;line-height:1.6}.hero-stats{display:flex;justify-content:center;gap:48px;margin-bottom:48px;flex-wrap:wrap}.stat{text-align:center}.stat-number{display:block;font-size:2.5rem;font-weight:700;color:#5170ff;margin-bottom:4px}.stat-label{font-size:.9rem;color:#b5b5b5;font-weight:500}.cta-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.cta-buttons .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 32px;border-radius:12px;font-size:1.1rem;font-weight:600;text-decoration:none;transition:all .3s ease;cursor:pointer;border:none}.cta-buttons .btn-primary{background:linear-gradient(135deg,#5170ff,#8b5cf6);color:#fff;box-shadow:0 4px 20px #5170ff4d}.cta-buttons .btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px #5170ff66}.cta-buttons .btn-secondary{background:transparent;color:#eaeaea;border:2px solid #333}.cta-buttons .btn-secondary:hover{background:#5170ff1a;border-color:#5170ff;transform:translateY(-3px)}.btn-arrow{transition:transform .3s ease}.btn:hover .btn-arrow{transform:translate(4px)}.section-header{text-align:center;margin-bottom:30px}.section-title{font-size:3rem;font-weight:700;margin:0 0 16px;color:#eaeaea}.section-subtitle{font-size:1.2rem;color:#b5b5b5;max-width:600px;margin:0 auto;line-height:1.6}.how-it-works{padding:60px 24px;background:linear-gradient(180deg,transparent 0%,rgba(81,112,255,.05) 100%)}.steps-container{max-width:1200px;margin:0 auto;width:100%}.steps-timeline{display:flex;flex-direction:column;gap:30px;position:relative}.steps-timeline:before{display:none}.step{display:flex;align-items:center;gap:40px;position:relative}.step:nth-child(2n){flex-direction:row-reverse}.step-visual{display:flex;align-items:center;justify-content:center;width:120px;height:120px;background:linear-gradient(135deg,#5170ff,#8b5cf6);border-radius:50%;position:relative;z-index:2;box-shadow:0 8px 30px #5170ff4d}.step-number{position:absolute;top:-10px;right:-10px;width:40px;height:40px;background:#0f0f10;border:3px solid #5170ff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#5170ff;font-size:1.1rem}.step-icon{font-size:3rem}.step-content{flex:1;max-width:400px}.step h3{font-size:1.8rem;margin:0 0 12px;color:#eaeaea}.step p{color:#b5b5b5;font-size:1.1rem;line-height:1.6;margin:0}.features{padding:60px 24px;background:#0a0a0a;border-radius:24px;margin:40px auto;max-width:1400px;width:100%}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:100%;margin:0 auto}.feature-card{background:linear-gradient(135deg,#1f1f1f,#2a2a2a);border:1px solid #333;border-radius:20px;padding:40px 30px;text-align:center;transition:all .3s ease;position:relative;overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#5170ff,#8b5cf6);transform:scaleX(0);transition:transform .3s ease}.feature-card:hover:before{transform:scaleX(1)}.feature-card:hover{transform:translateY(-8px);border-color:#5170ff;box-shadow:0 20px 40px #5170ff26}.feature-card-large{grid-column:span 2;background:linear-gradient(135deg,#1a1a2e,#16213e)}.feature-icon{font-size:3.5rem;margin-bottom:24px}.feature-card h3{font-size:1.6rem;margin:0 0 16px;color:#eaeaea}.feature-card p{color:#b5b5b5;font-size:1.1rem;line-height:1.6;margin:0 0 20px}.feature-highlight{display:inline-block;background:#5170ff1a;border:1px solid rgba(81,112,255,.3);border-radius:20px;padding:6px 16px;font-size:.9rem;color:#8b5cf6;font-weight:500}.social-proof{padding:60px 24px;background:linear-gradient(180deg,rgba(81,112,255,.05) 0%,transparent 100%);border-radius:24px;margin:40px auto;max-width:1400px;width:100%}.testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:100%;margin:0 auto}.testimonial{background:#1f1f1f;border:1px solid #333;border-radius:20px;padding:40px 30px;transition:all .3s ease}.testimonial:hover{transform:translateY(-5px);border-color:#5170ff;box-shadow:0 15px 30px #5170ff1a}.testimonial-content{font-size:1.1rem;line-height:1.6;color:#eaeaea;margin-bottom:24px;font-style:italic}.testimonial-author{display:flex;align-items:center;gap:16px}.author-avatar{width:50px;height:50px;background:linear-gradient(135deg,#5170ff,#8b5cf6);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.author-name{font-weight:600;color:#eaeaea;margin-bottom:2px}.author-role{font-size:.9rem;color:#b5b5b5}.final-cta{padding:60px 24px;background:linear-gradient(135deg,#5170ff1a,#8b5cf61a);border-radius:24px;text-align:center;margin:40px auto;max-width:1400px;width:100%}.cta-content{max-width:800px;margin:0 auto;width:100%}.cta-content h2{font-size:3rem;font-weight:700;margin:0 0 20px;color:#eaeaea}.cta-content p{font-size:1.3rem;color:#b5b5b5;margin:0 0 40px;line-height:1.6}.btn-large{padding:20px 40px;font-size:1.2rem}.cta-note{margin-top:30px;font-size:.9rem;color:#b5b5b5}@media(max-width:1024px){.steps-timeline:before{display:none}.step{flex-direction:column;text-align:center;gap:20px}.step:nth-child(2n){flex-direction:column}.feature-card-large{grid-column:span 1}.features,.social-proof,.final-cta{margin:30px auto;max-width:calc(100% - 64px)}}@media(max-width:768px){.hero-title{font-size:2.8rem}.hero-description{font-size:1.1rem}.hero-stats{gap:20px;margin-bottom:32px}.stat-number{font-size:2rem}.section-title{font-size:2.2rem}.section-subtitle{font-size:1.1rem}.cta-content h2{font-size:2.2rem}.features-grid,.testimonials{grid-template-columns:1fr;gap:20px}.cta-buttons{flex-direction:column;align-items:center}.cta-buttons .btn{width:100%;max-width:300px}.how-it-works,.features,.social-proof,.final-cta{padding:40px 16px}.features,.social-proof,.final-cta{margin:20px auto;max-width:calc(100% - 48px)}}@media(max-width:480px){.hero-section{padding:80px 12px 40px}.hero-title{font-size:2rem}.hero-description{font-size:1rem}.floating-element{font-size:1.2rem}.hero-stats{gap:16px;margin-bottom:24px}.stat-number{font-size:1.8rem}.stat-label{font-size:.8rem}.step-visual{width:80px;height:80px}.step-icon{font-size:2rem}.step-number{width:30px;height:30px;font-size:.9rem}.section-title{font-size:1.8rem}.section-subtitle{font-size:1rem}.how-it-works,.features,.social-proof,.final-cta{padding:30px 12px}.features,.social-proof,.final-cta{margin:16px auto;max-width:calc(100% - 32px);border-radius:16px}.feature-card,.testimonial{padding:24px 20px}.cta-content h2{font-size:1.8rem}.cta-content p{font-size:1.1rem}}#header-logo{height:100px;max-height:100%}header{display:flex;justify-content:space-between;align-items:center;padding:0 20px}.header-left,.header-center,.header-right{flex:1;display:flex;align-items:center;width:100%}.header-left{justify-content:flex-start}.header-center{justify-content:center}.header-right{justify-content:flex-end}@media(min-width:901px){header{position:relative}.header-left{position:absolute;left:50%;transform:translate(-50%);justify-content:center}.header-center{display:none}.header-right{flex:1;justify-content:flex-end}}.header-actions{display:flex;gap:10px}.view-saved-btn{background-color:#5170ff;color:#fff;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease;text-decoration:none;box-shadow:0 4px 10px #5170ff4d}.view-saved-btn:hover{background-color:#3a58e5;box-shadow:0 6px 14px #3a58e566;transform:translateY(-1px)}.menu-container{position:relative}.hamburger-menu{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.hamburger-icon{width:24px;height:24px;object-fit:contain}.dropdown-menu{position:absolute;top:100%;right:0;background-color:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;box-shadow:0 8px 24px #0000004d;min-width:160px;z-index:1000;overflow:hidden}.menu-item{display:block;width:100%;padding:12px 16px;color:#eaeaea;text-decoration:none;border:none;background:none;text-align:left;font-size:14px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #2a2a2a}.menu-item:last-child{border-bottom:none}.menu-item:hover{background-color:#2a2a2a;color:#5170ff}.logout-btn{color:#dc3545}.logout-btn:hover{background-color:#dc3545;color:#fff}@media(max-width:900px){#header-logo{height:100%;max-height:100px}header{padding:0 15px}.header-left,.header-center,.header-right{width:auto}.header-left{flex:1;justify-content:flex-start}.header-center{flex:0 0 auto;min-width:0;display:none}.header-right{flex:0 0 auto;min-width:40px}.dropdown-menu{min-width:140px}.menu-item{padding:10px 12px;font-size:13px}}.auth-page{min-height:100vh;background:#0f0f10;color:#eaeaea;display:flex;align-items:center;justify-content:center;padding:20px}.auth-container{width:100%;max-width:450px;background:#1f1f1f;border:1px solid #333;border-radius:20px;padding:40px;box-shadow:0 20px 40px #0000004d}.auth-header{text-align:center;margin-bottom:40px}.auth-logo{width:60px;height:60px;margin:0 auto 20px;background:linear-gradient(135deg,#5170ff,#8b5cf6);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff}.auth-title{font-size:2rem;font-weight:700;margin:0 0 8px;color:#eaeaea}.auth-subtitle{color:#b5b5b5;font-size:1rem;margin:0}.auth-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.9rem;font-weight:600;color:#eaeaea}.form-input{padding:14px 16px;background:#0f0f10;border:1px solid #333;border-radius:8px;color:#eaeaea;font-size:1rem;transition:all .2s ease}.form-input:focus{outline:none;border-color:#5170ff;box-shadow:0 0 0 3px #5170ff1a}.form-input::placeholder{color:#666}.form-error{color:#ff4757;font-size:.85rem;margin-top:4px}.auth-button{width:100%;padding:14px;background:#5170ff;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.auth-button:hover{background:#3a58e5;transform:translateY(-2px);box-shadow:0 8px 25px #5170ff4d}.auth-button:disabled{background:#333;cursor:not-allowed;transform:none;box-shadow:none}.auth-divider{display:flex;align-items:center;margin:24px 0;color:#666;font-size:.9rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#333}.auth-divider span{padding:0 16px}.auth-link{text-align:center;margin-top:24px;color:#b5b5b5;font-size:.9rem}.auth-link a{color:#5170ff;text-decoration:none;font-weight:600;transition:color .2s ease}.auth-link a:hover{color:#3a58e5}.password-toggle{position:relative}.password-toggle-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);cursor:pointer;color:#666;font-size:1.2rem;transition:color .2s ease;margin-left:10px}.password-toggle-icon:hover{color:#eaeaea}.password-toggle input{padding-right:45px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.remember-forgot{display:flex;justify-content:space-between;align-items:center;margin:-8px 0 0}.checkbox-group{display:flex;align-items:center;gap:8px}.checkbox-group input[type=checkbox]{width:16px;height:16px;accent-color:#5170ff}.checkbox-group label{font-size:.9rem;color:#b5b5b5;cursor:pointer}.forgot-link{color:#5170ff;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s ease}.forgot-link:hover{color:#3a58e5}.auth-button.loading{position:relative;color:transparent}.auth-button.loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner.large{width:40px;height:40px;border-width:4px}.loading-spinner.primary{border:2px solid rgba(81,112,255,.3);border-top:2px solid #5170ff}.loading-spinner.primary.large{border-width:4px}.auth-message{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.9rem;font-weight:500}.auth-message.success{background:#2ecc711a;border:1px solid rgba(46,204,113,.3);color:#2ecc71}.auth-message.error{background:#ff47571a;border:1px solid rgba(255,71,87,.3);color:#ff4757}.password-strength{margin-top:8px}.strength-bar{width:100%;height:4px;background:#333;border-radius:2px;overflow:hidden;margin-bottom:4px}.strength-fill{height:100%;transition:all .3s ease}.strength-0{background:#ff4757}.strength-1{background:#ff6b7a}.strength-2{background:#ffa502}.strength-3{background:#ffdd59}.strength-4{background:#7bed9f}.strength-5{background:#2ed573}.strength-text{font-size:.8rem;color:#b5b5b5;font-weight:500}.password-requirements{margin-top:8px;padding:8px 0}.requirement{font-size:.8rem;margin:2px 0;display:flex;align-items:center;transition:color .2s ease}.requirement.valid{color:#2ed573}.requirement.invalid{color:#ff4757}.requirement:before{content:"";width:12px;height:12px;margin-right:6px;border-radius:50%;display:inline-block;transition:all .2s ease}.requirement.valid:before{background:#2ed573;content:"✓";color:#fff;font-size:8px;display:flex;align-items:center;justify-content:center}.requirement.invalid:before{background:#ff4757;content:"✗";color:#fff;font-size:8px;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.auth-container{padding:30px 24px;margin:10px}.auth-title{font-size:1.75rem}.form-row{grid-template-columns:1fr;gap:16px}.remember-forgot{flex-direction:column;align-items:flex-start;gap:12px}}@media(max-width:480px){.auth-page{padding:10px}.auth-container{padding:24px 20px}.auth-title{font-size:1.5rem}.form-input{padding:12px 14px}.auth-button{padding:12px}}.chatbot-container{background:linear-gradient(135deg,#1a1f2e,#2a3441);border:2px solid #5170ff;border-radius:16px;max-width:800px;margin:30px auto;padding:0;box-shadow:0 8px 32px #5170ff33;display:flex;flex-direction:column;height:600px;overflow:hidden}.chatbot-header{background:linear-gradient(135deg,#5170ff,#6b7fff);padding:20px;border-radius:14px 14px 0 0;box-shadow:0 4px 12px #5170ff4d}.chatbot-header h2{margin:0;color:#fafaf8;font-size:1.5rem;font-weight:600;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.1)}.chatbot-subtitle{margin:5px 0 0;color:#e8e8ff;font-size:.875rem;text-align:center;opacity:.9}.chat-messages{flex:1;overflow-y:auto;padding:20px;background-color:#0d1117;display:flex;flex-direction:column;gap:12px}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:#1a1f2e;border-radius:4px}.chat-messages::-webkit-scrollbar-thumb{background:#5170ff;border-radius:4px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#6b7fff}.chat-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#888;text-align:center;padding:40px 20px}.chat-empty-state-icon{font-size:3rem;margin-bottom:15px;opacity:.5}.chat-empty-state p{margin:8px 0;font-size:1rem;line-height:1.5}.chat-empty-state p:first-of-type{font-weight:600;color:#aaa;font-size:1.1rem}.chatbot-msg,.user-msg{padding:12px 16px;border-radius:12px;max-width:75%;word-wrap:break-word;line-height:1.5;font-size:.95rem;animation:messageSlideIn .3s ease-out;box-shadow:0 2px 8px #0003}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chatbot-msg{background:linear-gradient(135deg,#2a2a2a,#333);color:#eaeaea;align-self:flex-start;border:1px solid #444;border-left:4px solid #5170ff}.user-msg{background:linear-gradient(135deg,#5170ff,#6b7fff);color:#fafaf8;align-self:flex-end;border:1px solid #6b7fff;box-shadow:0 4px 12px #5170ff4d}.chat-input-wrapper{background-color:#1a1f2e;padding:20px;border-top:1px solid #333}.chat-input{display:flex;gap:12px;align-items:center}.chat-input input{flex:1;padding:14px 18px;border:2px solid #444;border-radius:10px;background-color:#2a2a2a;color:#eaeaea;font-size:.95rem;transition:all .3s ease;outline:none}.chat-input input::placeholder{color:#888;font-style:italic}.chat-input input:hover{border-color:#5170ff;background-color:#2d2d2d}.chat-input input:focus{border-color:#5170ff;background-color:#333;box-shadow:0 0 0 4px #5170ff33}.chat-send-btn{background:linear-gradient(135deg,#5170ff,#6b7fff);color:#fafaf8;border:none;border-radius:10px;padding:14px 28px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #5170ff66;display:flex;align-items:center;gap:8px;white-space:nowrap}.chat-send-btn:hover:not(:disabled){background:linear-gradient(135deg,#3a58e5,#5a9eff);box-shadow:0 6px 16px #5170ff80;transform:translateY(-2px)}.chat-send-btn:active:not(:disabled){transform:translateY(0) scale(.98);box-shadow:0 2px 8px #5170ff66}.chat-send-btn:disabled{background:linear-gradient(135deg,#555,#666);cursor:not-allowed;opacity:.6;box-shadow:none}.chat-loading,.chat-refining{display:flex;align-items:center;gap:8px;padding:12px 16px;background-color:#2a2a2a;border-radius:12px;max-width:75%;align-self:flex-start;border:1px solid #444;border-left:4px solid #5170ff}.chat-refining{background:linear-gradient(135deg,#2a2a2a,#3a2a4a);border-left:4px solid #b084ff;max-width:85%}.chat-loading-dots{display:flex;gap:4px;align-items:center}.chat-loading-dot{width:8px;height:8px;background-color:#5170ff;border-radius:50%;animation:loadingBounce 1.4s infinite ease-in-out both}.chat-loading-dot:nth-child(1){animation-delay:-.32s}.chat-loading-dot:nth-child(2){animation-delay:-.16s}@keyframes loadingBounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-loading-text{color:#888;font-size:.9rem;font-style:italic}@media(max-width:768px){.chatbot-container{margin:20px 16px;height:500px;max-width:100%}.chatbot-header h2{font-size:1.3rem}.chatbot-subtitle{font-size:.8rem}.chat-messages{padding:15px;gap:10px}.chatbot-msg,.user-msg{max-width:85%;padding:10px 14px;font-size:.9rem}.chat-input-wrapper{padding:15px}.chat-input{flex-direction:column;gap:10px}.chat-input input{width:100%;padding:12px 16px}.chat-send-btn{width:100%;justify-content:center;padding:12px 20px}.chat-empty-state{padding:30px 15px}.chat-empty-state-icon{font-size:2.5rem}.chat-empty-state p{font-size:.9rem}.chat-empty-state p:first-of-type{font-size:1rem}}@media(max-width:480px){.chatbot-container{height:450px;border-radius:12px}.chatbot-header{padding:15px}.chatbot-header h2{font-size:1.2rem}.chat-messages{padding:12px}.chatbot-msg,.user-msg{max-width:90%;padding:9px 12px;font-size:.875rem}}.dashboard-container{min-height:100vh;background-color:#0f0f10;color:#eaeaea}.save-recommendations-section{background-color:#1a1f2e;border:1px solid #2a3441;border-radius:8px;padding:20px;margin:25px auto;box-shadow:0 2px 8px #0000001a;max-width:70%}.save-section-header{text-align:center;margin-bottom:20px}.save-section-header h3{color:#eaeaea;font-size:1.3rem;font-weight:500;margin:0 0 8px}.save-section-header p{color:#b0b0b0;font-size:.95rem;margin:0;font-weight:400}.save-section{display:flex;align-items:end;gap:16px;flex-wrap:wrap;justify-content:center}.trip-name-group{display:flex;flex-direction:column;gap:8px;flex:1;min-width:250px}.trip-name-label{color:#eaeaea;font-weight:500;font-size:.9rem;margin:0}.trip-title-input{border-radius:8px;border:2px solid #333;padding:12px 16px;background-color:#1e1e1e;color:#eaeaea;font-size:1rem;transition:all .3s ease;min-width:250px}.trip-title-input:focus{outline:none;border-color:#5170ff;background-color:#252525}.trip-title-input::placeholder{color:#888;font-style:italic}.save-btn{background-color:#5170ff;color:#fff;border:none;border-radius:6px;padding:10px 20px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background-color .2s ease;min-width:180px;height:fit-content}.save-btn:hover:not(:disabled){background-color:#3a58e5}.save-btn:disabled{background-color:#6c757d;cursor:not-allowed}.recommendations-chatbot-wrapper{display:flex;gap:30px;margin-top:20px;max-width:95%;margin-left:auto;margin-right:auto;align-items:flex-start}.recommendations-content{flex:3;min-width:400px;background:linear-gradient(135deg,#1a1f2e,#2a3441);border-radius:20px;padding:32px;box-shadow:0 12px 40px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.recommendations-content h2{color:#eaeaea;font-size:1.8rem;font-weight:700;margin-bottom:32px;text-align:left;background:linear-gradient(135deg,#eaeaea,#b0b0b0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;border-bottom:2px solid #3a4a5c;padding-bottom:16px}.recommendations-content h1,.recommendations-content h2,.recommendations-content h3,.recommendations-content h4,.recommendations-content h5,.recommendations-content h6{color:#eaeaea;text-align:left;margin-top:32px;margin-bottom:16px;font-size:1.4rem;font-weight:600;position:relative}.recommendations-content h1:first-of-type,.recommendations-content h2:first-of-type,.recommendations-content h3:first-of-type,.recommendations-content h4:first-of-type,.recommendations-content h5:first-of-type,.recommendations-content h6:first-of-type{margin-top:0}.recommendations-content ul,.recommendations-content ol{text-align:left;margin-bottom:24px;padding-left:0;list-style-type:none}.recommendations-content li{background:linear-gradient(135deg,#2a3441,#3a4a5c);color:#eaeaea;margin-bottom:12px;line-height:1.6;padding:16px 20px;border-radius:12px;border:1px solid #3a4a5c;box-shadow:0 4px 12px #0003;transition:all .3s ease;position:relative;font-weight:500}.recommendations-content li:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0000004d;border-color:#5170ff}.recommendations-content li:before{content:"✓";color:#5170ff;font-weight:700;margin-right:12px;font-size:1.1rem}.recommendations-content p{text-align:left;margin-bottom:20px;color:#ccc;line-height:1.6;font-size:1.05rem}.chatbot-section{flex:1;position:sticky;top:20px;align-self:flex-start}.chatbot-section .chatbot-container{margin:0;max-width:100%;height:600px;transform:scale(.87);transform-origin:top center}.loading-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid #ffffff;border-radius:50%;animation:spin 1s ease-in-out infinite;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}button.loading{opacity:.8;cursor:not-allowed}button.loading:hover{transform:none}@media(max-width:768px){.save-recommendations-section{padding:16px;margin:25px 0;max-width:100%;width:100%}.save-section-header h3{font-size:1.2rem}.save-section-header p{font-size:.9rem}.save-section{flex-direction:column;align-items:stretch;gap:16px}.trip-name-group{min-width:unset}.trip-title-input{min-width:unset;width:100%}.save-btn{min-width:unset;width:100%;padding:12px 20px}.recommendations-content{max-width:100%;margin-left:0;margin-right:0;padding:0 16px}.recommendations-content h2{font-size:1.3rem}.recommendations-content h1,.recommendations-content h2,.recommendations-content h3,.recommendations-content h4,.recommendations-content h5,.recommendations-content h6{font-size:1.1rem;margin-top:20px}.recommendations-content ul,.recommendations-content ol{padding-left:16px}.recommendations-chatbot-wrapper{flex-direction:column;max-width:100%;gap:20px}.chatbot-section{flex:1;position:static;width:100%}.chatbot-section .chatbot-container{height:500px}}.saved-recommendations-page{min-height:100vh;background-color:#0d1117;color:#eaeaea}.page-header{display:flex;align-items:center;gap:20px;padding:20px;border-bottom:1px solid #333;background-color:#1e1e1e}.back-btn{background-color:#5170ff;color:#fff;text-decoration:none;padding:10px 20px;border-radius:6px;font-weight:500;transition:background-color .2s ease}.back-btn:hover{background-color:#3a58e5}.page-header h1{margin:0;color:#eaeaea}.recommendations-container{display:flex;min-height:calc(100vh - 80px)}.recommendations-list{width:40%;border-right:1px solid #333;overflow-y:auto;padding:20px}.recommendation-item{background-color:#2a2a2a;border-radius:8px;padding:15px;margin-bottom:15px;cursor:pointer;transition:background-color .2s ease;border:2px solid transparent;position:relative}.recommendation-item:hover{background-color:#333}.recommendation-item.active{border-color:#5170ff;background-color:#333}.recommendation-preview h3{color:#eaeaea;margin:0 0 8px;font-size:16px}.trip-summary{color:#bbb;font-size:14px;margin:8px 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.packed-count{color:#888;font-size:12px;margin:4px 0}.created-date{color:#666;font-size:12px;margin:4px 0 0}.delete-btn{position:absolute;top:10px;right:10px;background-color:#dc3545;color:#fff;border:none;border-radius:4px;padding:4px 8px;font-size:12px;cursor:pointer;transition:background-color .2s ease}.delete-btn:hover{background-color:#c82333}.recommendation-details{width:60%;padding:20px;overflow-y:auto}.details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.details-header h2{color:#eaeaea;margin:0}.trip-info,.packed-items,.ai-recommendations,.uploaded-image{margin-bottom:25px}.trip-info h3,.packed-items h3,.ai-recommendations h3,.uploaded-image h3{color:#eaeaea;margin:0 0 10px;font-size:18px}.trip-info p{color:#bbb;line-height:1.5}.uploaded-image{background-color:#2a2a2a;padding:15px;border-radius:8px;border:1px solid #333}.uploaded-image img{box-shadow:0 2px 8px #0000004d;transition:transform .2s ease}.uploaded-image img:hover{transform:scale(1.02)}.packed-items ul{list-style-type:none;padding:0}.packed-items li{background-color:#2a2a2a;color:#eaeaea;padding:8px 12px;margin-bottom:5px;border-radius:4px}.ai-recommendations,.ai-recommendations h1,.ai-recommendations h2,.ai-recommendations h3{color:#eaeaea}.ai-recommendations ul,.ai-recommendations ol{color:#bbb}.no-recommendations{text-align:center;padding:40px 20px;color:#888}.no-recommendations h3{color:#eaeaea;margin-bottom:10px}.btn-primary{display:inline-block;background-color:#5170ff;color:#fff;text-decoration:none;padding:12px 24px;border-radius:6px;font-weight:500;transition:background-color .2s ease}.btn-primary:hover{background-color:#3a58e5}.loading{color:#eaeaea;text-align:center;padding:40px 20px}.error-message{background-color:#f8d7da;color:#721c24;padding:10px 15px;border-radius:6px;margin:20px;border:1px solid #f5c6cb}@media(max-width:768px){.recommendations-container{flex-direction:column}.recommendations-list{width:100%;border-right:none;border-bottom:1px solid #333;max-height:300px}.recommendation-details{width:100%}.page-header{flex-direction:column;align-items:stretch;gap:10px}}
