@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&family=Source+Sans+3:wght@300;400;500;600&display=swap";:root{--color-navy: #1a2a44;--color-navy-light: #2d4263;--color-gold: #d4af37;--color-gold-light: #e8c85c;--color-cream: #fdf9f0;--color-white: #ffffff;--color-burgundy: #722f37;--color-burgundy-light: #8b3a42;--color-text-primary: #1a2a44;--color-text-secondary: #5a6a7a;--color-text-muted: #8a9aaa;--font-heading: "Playfair Display", Georgia, serif;--font-body: "Source Sans 3", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:linear-gradient(135deg,#f5f0e8,#fdf9f0,#f8f4ec);color:var(--color-text-primary);line-height:1.6;min-height:100vh}body:before{content:"";position:fixed;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(212,175,55,.05) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(26,42,68,.03) 0%,transparent 50%),url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%231a2a44' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none;z-index:-1}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.3}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#1a2a440d}::-webkit-scrollbar-thumb{background:var(--color-navy-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-navy)}::selection{background:var(--color-gold);color:var(--color-navy)}.location-card{display:flex;gap:1rem;position:relative;padding-bottom:.5rem}.location-card.completed .card-content{opacity:.6}.location-card.completed .location-name{text-decoration:line-through}.timeline-marker{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.marker-dot{width:36px;height:36px;border-radius:50%;background:var(--color-cream);border:3px solid var(--color-navy);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;position:relative;z-index:2}.marker-dot:hover{transform:scale(1.1);box-shadow:0 0 0 4px #1a2a441a}.marker-dot.active{background:var(--color-gold);border-color:var(--color-gold);box-shadow:0 0 0 4px #d4af374d}.marker-dot.completed{background:var(--color-navy);border-color:var(--color-navy)}.marker-dot.completed .marker-number{color:var(--color-cream)}.marker-number{font-family:var(--font-heading);font-size:.875rem;font-weight:600;color:var(--color-navy)}.marker-dot.active .marker-number{color:var(--color-navy)}.timeline-line{width:3px;flex:1;min-height:40px;background:linear-gradient(to bottom,var(--color-navy) 0%,var(--color-navy-light) 100%);margin-top:-2px}.card-content{flex:1;background:var(--color-cream);border-radius:12px;padding:1rem 1.25rem;box-shadow:0 2px 8px #0000000f;border:1px solid rgba(26,42,68,.08);transition:all .3s ease}.location-card.active .card-content{border-color:var(--color-gold);box-shadow:0 4px 16px #d4af3733}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.location-name{font-family:var(--font-heading);font-size:1.125rem;font-weight:600;color:var(--color-navy);margin:0;line-height:1.3}.maps-link{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:var(--color-navy);color:var(--color-cream);transition:all .2s ease;flex-shrink:0}.maps-link:hover{background:var(--color-gold);color:var(--color-navy);transform:scale(1.05)}.maps-icon{width:16px;height:16px}.location-notes{margin:.5rem 0 0;font-size:.875rem;color:var(--color-text-secondary);font-style:italic}.travel-time{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.75rem;padding-top:.75rem;border-top:1px dashed rgba(26,42,68,.15)}.travel-mode{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--color-text-secondary);background:#1a2a440d;padding:.25rem .625rem;border-radius:20px}.travel-icon{width:14px;height:14px}.travel-mode.walking{color:var(--color-navy)}.travel-mode.transit{color:var(--color-burgundy)}.day-section{background:var(--color-white);border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #00000014;border:1px solid rgba(26,42,68,.06);transition:all .3s ease}.day-section:hover{box-shadow:0 6px 24px #0000001a}.day-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:linear-gradient(135deg,var(--color-navy) 0%,var(--color-navy-light) 100%);border:none;cursor:pointer;text-align:left;transition:all .3s ease}.day-header:hover{background:linear-gradient(135deg,var(--color-navy-light) 0%,var(--color-navy) 100%)}.day-info{display:flex;flex-direction:column;gap:.25rem}.day-title{font-family:var(--font-heading);font-size:1.375rem;font-weight:700;color:var(--color-cream);margin:0}.day-subtitle{font-size:.875rem;color:#fdf9f0bf;font-weight:400}.day-meta{display:flex;align-items:center;gap:1rem}.progress-indicator{display:flex;align-items:center;gap:.5rem}.progress-bar{width:60px;height:6px;background:#fdf9f033;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--color-gold);border-radius:3px;transition:width .3s ease}.progress-text{font-size:.75rem;color:#fdf9f0cc;font-weight:500;min-width:32px}.expand-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#fdf9f026;color:var(--color-cream);transition:all .3s ease}.expand-icon svg{width:16px;height:16px;transition:transform .3s ease}.expand-icon.expanded svg{transform:rotate(180deg)}.day-content{max-height:0;overflow:hidden;transition:max-height .4s ease-out}.day-section.expanded .day-content{max-height:5000px;transition:max-height .6s ease-in}.locations-list{padding:1.5rem;background:linear-gradient(180deg,#1a2a4405,#fdf9f080)}@media(max-width:480px){.day-header{padding:1rem 1.25rem}.day-title{font-size:1.25rem}.progress-bar{width:48px}.locations-list{padding:1rem}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,var(--color-navy) 0%,var(--color-navy-light) 50%,var(--color-navy) 100%);color:var(--color-cream);padding:2rem 1.5rem 1.5rem;text-align:center;position:relative;overflow:hidden}.app-header:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 70%,rgba(212,175,55,.1) 0%,transparent 50%),radial-gradient(circle at 70% 30%,rgba(212,175,55,.08) 0%,transparent 40%);pointer-events:none}.header-decoration{margin-bottom:.5rem}.header-flourish{width:80px;height:16px;color:var(--color-gold);opacity:.8}.app-title{font-family:var(--font-heading);font-size:3rem;font-weight:700;letter-spacing:.15em;margin:0;text-transform:uppercase;background:linear-gradient(135deg,var(--color-cream) 0%,var(--color-gold) 50%,var(--color-cream) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.app-subtitle{font-size:1.1rem;opacity:.9;margin-top:.25rem;letter-spacing:.05em;font-style:italic}.app-names{font-size:1rem;opacity:.85;margin-top:.5rem;letter-spacing:.08em;color:var(--color-gold-light);font-weight:500}.app-dates{font-size:.875rem;opacity:.7;margin-top:.25rem;letter-spacing:.03em}.overall-progress{margin-top:1.5rem;padding:0 1rem}.overall-progress-bar{height:8px;background:#fdf9f026;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.overall-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-gold) 0%,var(--color-gold-light) 100%);border-radius:4px;transition:width .5s ease}.overall-progress-text{font-size:.8125rem;opacity:.75}.reset-button{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.5rem 1rem;background:#fdf9f01a;border:1px solid rgba(253,249,240,.2);border-radius:20px;color:var(--color-cream);font-size:.8125rem;transition:all .2s ease}.reset-button:hover{background:#fdf9f033;border-color:#fdf9f04d}.reset-button svg{width:14px;height:14px}.app-main{flex:1;padding:1.5rem;max-width:600px;margin:0 auto;width:100%}.sections-container{display:flex;flex-direction:column;gap:1rem}.app-footer{background:var(--color-navy);color:var(--color-cream);padding:1rem 1.5rem;text-align:center}.footer-content{display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.7}.footer-icon{width:24px;height:24px}.footer-icon svg{width:100%;height:100%}.app-footer p{font-size:.8125rem;margin:0}.footer-hint{font-size:.75rem!important;opacity:.6;margin-top:.25rem!important}@media(max-width:480px){.app-header{padding:1.5rem 1rem 1.25rem}.app-title{font-size:2.5rem}.app-main{padding:1rem}}@media(min-width:768px){.app-header{padding:2.5rem 2rem 2rem}.app-title{font-size:3.5rem}.app-main{padding:2rem}.overall-progress{max-width:400px;margin-left:auto;margin-right:auto}}
