.home-container{min-height:100vh;padding:1.5rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;justify-content:center;align-items:center;text-align:center}.hero-section{max-width:900px;margin:0 auto;padding:2.5rem 2rem;background:#fffffff2;border-radius:20px;box-shadow:0 10px 30px #0000001a}.app-title{font-size:3.5rem;color:#2c3e50;margin-bottom:.75rem;font-weight:700;background:linear-gradient(45deg,#2c3e50,#3498db);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.tagline{font-size:1.25rem;color:#666;margin-bottom:2rem}.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin:2rem 0;max-width:800px;margin-left:auto;margin-right:auto}.feature-card{padding:1.5rem;background:#fff;border-radius:15px;box-shadow:0 5px 15px #0000000d;transition:transform .3s ease}.feature-card:hover{transform:translateY(-5px)}.feature-icon{font-size:2rem;margin-bottom:.75rem;display:block}.feature-card h3{color:#2c3e50;margin-bottom:.5rem;font-size:1.15rem}.feature-card p{color:#666;font-size:.95rem}.cta-button{background:linear-gradient(45deg,#3498db,#2980b9);color:#fff;border:none;padding:.875rem 2.5rem;font-size:1.15rem;border-radius:50px;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;margin-top:1.5rem}.cta-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #3498db4d}@media (max-width: 640px){.app-title{font-size:2.5rem}.tagline{font-size:1.1rem}.features-grid{grid-template-columns:1fr}.home-container{padding:1rem}.hero-section{padding:1.5rem 1rem}.feature-card{padding:1.25rem}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1rem}.spinner{position:relative;display:inline-block}.spinner.small{width:24px;height:24px}.spinner.medium{width:40px;height:40px}.spinner.large{width:60px;height:60px}.spinner-ring{position:absolute;width:100%;height:100%;border:3px solid transparent;border-top:3px solid var(--spinner-color, #3b82f6);border-radius:50%;animation:spin 1.2s linear infinite}.spinner-ring:nth-child(1){animation-delay:0s}.spinner-ring:nth-child(2){animation-delay:-.4s;border-top-color:transparent;border-right:3px solid var(--spinner-color, #3b82f6)}.spinner-ring:nth-child(3){animation-delay:-.8s;border-top-color:transparent;border-right-color:transparent;border-bottom:3px solid var(--spinner-color, #3b82f6)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{margin:0;font-size:.875rem;color:#6b7280;font-weight:500;text-align:center}.loading-text{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}@media (max-width: 768px){.spinner.medium{width:32px;height:32px}.spinner.large{width:48px;height:48px}.loading-text{font-size:.75rem}}.trips-page{display:flex;flex-direction:column;height:100vh;width:100%}.trips-container{display:flex;flex:1;overflow:hidden}.left-panel{width:350px;padding:1rem;overflow-y:auto;border-right:1px solid #e0e0e0;background-color:#f9f9f9;display:flex;flex-direction:column}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #e0e0e0}.map-container{flex:1;position:relative}.trip-cards-container,.place-cards-container{overflow-y:auto}.trip-card,.place-card{background-color:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:transform .2s}.place-card{position:relative;background-color:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:all .3s ease;margin:8px 0;z-index:1}.place-card.selected{border-color:#3498db;background-color:#f8faff;box-shadow:0 2px 8px #3498db33;transform:translate(-4px)}.place-card.minimized{padding:12px 16px}.place-card.minimized .place-card-content{display:none}.place-name{margin:0 32px 0 24px;font-size:1.1em;font-weight:500;color:#1f2937}.place-card:not(.minimized) .place-name{margin-bottom:.5rem}.place-address{margin:0 0 1rem;color:#6b7280;font-size:.875rem}.minimize-toggle{position:absolute;top:12px;right:12px;width:32px;height:32px;background:#fff;border:2px solid #e5e7eb;border-radius:6px;color:#4b5563;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:2;padding:0}.place-card.minimized .minimize-toggle{top:6px}.minimize-toggle:hover{color:#3b82f6;background:#f8fafc;border-color:#3b82f6;transform:scale(1.05)}.minimize-toggle svg{width:20px;height:20px;stroke-width:2.5}.place-card-content{margin-top:12px;opacity:1;height:auto;overflow:hidden;transition:all .3s ease}.place-card-content.hidden{opacity:0;height:0;margin-top:0}.add-place-button{position:absolute;left:50%;transform:translate(-50%) translateY(-50%) scale(.9);opacity:0;background-color:#fff;border-radius:20px;padding:8px 16px;display:flex;align-items:center;gap:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:all .2s ease;border:1px solid #e5e7eb;color:#3b82f6;z-index:2}.add-place-button.before{top:0}.add-place-button.after{bottom:0}.add-place-button:hover{transform:translate(-50%) translateY(-50%) scale(1);box-shadow:0 4px 6px #0000001a;background-color:#f8fafc}.place-card-wrapper:hover .add-place-button.before{opacity:1;transform:translate(-50%) translateY(-50%) scale(1)}.place-card-wrapper:hover .add-place-button.after{opacity:1;transform:translate(-50%) translateY(50%) scale(1)}.add-icon{display:flex;align-items:center;justify-content:center}.add-place-form{background-color:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 4px #0000001a;border:1px solid #e5e7eb;margin:1rem 0}.add-place-form.before{margin-bottom:1rem}.add-place-form.after{margin-top:1rem}.add-place-form h5{margin:0 0 1rem;color:#4b5563}.activities-section{margin-top:1rem;border-top:1px solid #e5e7eb;padding-top:1rem}.activities-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.activities-header h5{margin:0;color:#4b5563}.add-activity-button{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;font-size:.875rem;color:#3b82f6;background:transparent;border:1px dashed #3b82f6;border-radius:4px;cursor:pointer;transition:all .2s ease}.add-activity-button:hover{background-color:#3b82f61a}.add-activity-form{margin:1rem 0;padding:1rem;background-color:#f9fafb;border-radius:4px}.activities-list{display:flex;flex-direction:column;gap:.5rem}.activity-item{background-color:#f9fafb;border-radius:4px;overflow:hidden}.activity-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;cursor:pointer;transition:background-color .2s ease}.activity-header:hover{background-color:#f3f4f6}.activity-name{display:flex;align-items:center;gap:.5rem;font-weight:500}.activity-actions{display:flex;gap:.5rem}.activity-actions button{padding:.25rem;background:transparent;border:none;color:#6b7280;cursor:pointer;transition:color .2s ease}.activity-actions button:hover{color:#ef4444}.activity-details{padding:.75rem;background-color:#fff;border-top:1px solid #e5e7eb}.activity-address{font-size:.875rem;color:#6b7280;margin:0 0 .5rem}.activity-notes{background-color:#f3f4f6;padding:.5rem;border-radius:4px;margin-top:.5rem}.activity-notes p{margin:0 0 .5rem;font-size:.875rem}.activity-notes button,.activity-details button{font-size:.875rem;color:#3b82f6;background:transparent;border:none;padding:0;cursor:pointer}.activity-notes button:hover,.activity-details button:hover{text-decoration:underline}.place-index{position:absolute;top:8px;left:5px;width:30px;height:20px;background-color:#3498db;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;z-index:999}.card-actions,.place-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.back-button{padding:.5rem;background-color:transparent;border:none;cursor:pointer;color:#3498db;font-weight:700;display:flex;align-items:center}.create-button{padding:.5rem 1rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer}.create-trip-form,.add-place-container{background-color:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 4px #0000001a}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:700}.form-group input,.form-group textarea{width:100%;padding:.5rem;border:1px solid #e0e0e0;border-radius:4px}.form-actions{display:flex;justify-content:flex-end;gap:.5rem}.form-control{width:100%}button{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;background-color:#f0f0f0}button[type=submit],.create-button{background-color:#3498db;color:#fff}.no-trips-message,.no-places-message{text-align:center;color:#7f8c8d;margin:2rem 0}.place-notes{background-color:#f9f9f9;padding:.8rem;border-radius:4px;margin:.7rem 0;position:relative;border-left:3px solid #3498db}.edit-icon{position:absolute;top:7px;left:7px;opacity:.7;background-color:#fffc;border-radius:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#3498db;transition:all .2s ease}.edit-icon:hover{opacity:1;background-color:#fff;box-shadow:0 1px 3px #0000001a}.notes-editor{margin:.7rem 0;position:relative;overflow:visible}.styled-textarea{width:100%;padding:.8rem;border:1px solid #e0e0e0;border-radius:4px;min-height:100px;max-height:200px;background-color:#fff;font-family:inherit;font-size:inherit;color:inherit;resize:vertical;transition:border-color .2s;box-sizing:border-box}.styled-textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.notes-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.notes-button{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s}.save-button{background-color:#3498db;color:#fff}.save-button:hover{background-color:#2980b9}.cancel-button{background-color:#f1f1f1;color:#333}.cancel-button:hover{background-color:#e0e0e0}.add-notes-button{display:inline-block;background:transparent;color:#3498db;border:1px dashed #3498db;border-radius:4px;padding:.4rem .8rem;margin:.5rem 0;cursor:pointer;transition:all .2s}.add-notes-button:hover{background-color:#3498db1a}.add-place-after{margin-top:1rem;padding-top:1rem;border-top:1px dashed #e0e0e0}.place-search-container{margin:.7rem 0;width:100%}.search-input-wrapper{position:relative}.search-input{width:100%;padding:.8rem .8rem .8rem 1rem;border:1px solid #e0e0e0;border-radius:4px;background-color:#fff;font-family:inherit;font-size:inherit;color:inherit;transition:border-color .2s;box-sizing:border-box}.search-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.search-input::placeholder{color:#aaa}.search-input:disabled{background-color:#f9f9f9;cursor:not-allowed}.loading-text{margin-top:.5rem;font-size:.85rem;color:#7f8c8d}.pac-container{border-radius:4px;border:1px solid #e0e0e0;box-shadow:0 4px 6px #0000001a;margin-top:2px;font-family:inherit}.pac-item{padding:8px 10px;cursor:pointer}.pac-item:hover{background-color:#f5f9ff}.pac-item-selected,.pac-item-selected:hover{background-color:#ebf5ff}.pac-icon{margin-right:10px}.pac-item-query{font-size:inherit;color:#333}.pac-matched{font-weight:700;color:#3498db}.place-cards-container{overflow-y:auto;padding-left:8px}.place-card-wrapper{position:relative;margin:2rem 0}@media screen and (max-width: 768px){.trips-container{flex-direction:column;height:100vh}.left-panel{width:100%;height:50vh;border-right:none;border-bottom:1px solid #e0e0e0}.map-container{height:50vh}.panel-header h2{font-size:1.2rem;margin:0}.place-card{margin:8px 4px}.add-place-button{transform:translate(-50%) translateY(-50%) scale(.8)}.place-card-wrapper:hover .add-place-button{transform:translate(-50%) translateY(-50%) scale(.9)}.place-search-container{margin:.5rem 0}.search-input{padding:.6rem}.form-group input,.form-group textarea{padding:.4rem}.notes-editor{margin:.5rem 0}.styled-textarea{min-height:80px}}@media screen and (max-width: 480px){.left-panel{padding:.5rem}.panel-header{margin-bottom:.5rem;padding-bottom:.25rem}.back-button{padding:.25rem}.place-name{font-size:1rem;margin:0 24px 0 20px}.place-card{padding:12px}.minimize-toggle{width:28px;height:28px}}
