:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f6f2ea;color:#1c2526;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--ink: #1c2526;--muted: #657477;--paper: #fffaf2;--surface: #ffffff;--line: rgba(31, 77, 87, .18);--tile-blue: #1f4d57;--tile-blue-2: #286b78;--terracotta: #a94d35;--rose: #b2445d;--palm: #34724f;--ochre: #c89334;--shadow: 0 18px 40px rgba(26, 33, 32, .14);--radius: 8px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#1f4d5714,#1f4d5700 320px),#f6f2ea}button,input,textarea,select{font:inherit}button{border:0}button,a{-webkit-tap-highlight-color:transparent}.app-shell{min-height:100vh;padding-bottom:env(safe-area-inset-bottom)}.hero{position:relative;min-height:290px;display:flex;align-items:flex-end;padding:24px 18px 26px;overflow:hidden;background-image:url(/morocco-cover.png);background-position:center;background-size:cover;color:#fff}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0e181852,#0e18181a 40%,#0b1312d1),linear-gradient(90deg,#0f2123b8,#0f21231f 62%)}.hero-copy,.hero-actions{position:relative;z-index:1}.hero-copy h1,.gate-panel h1{margin:6px 0 12px;font-size:2.35rem;line-height:1;letter-spacing:0}.hero-actions{position:absolute;right:16px;top:calc(16px + env(safe-area-inset-top))}.hero-stats{display:flex;flex-wrap:nowrap;gap:8px;max-width:100%;overflow-x:auto;scrollbar-width:none}.hero-stats::-webkit-scrollbar{display:none}.hero-stats span,.quick-strip span{display:inline-flex;align-items:center;gap:6px;min-height:34px;padding:7px 10px;border-radius:999px;background:#ffffff24;color:inherit;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap}.eyebrow{margin:0;color:currentColor;font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;opacity:.78}.day-rail{position:sticky;top:0;z-index:5;display:flex;gap:10px;padding:12px 14px;overflow-x:auto;background:#f6f2eaeb;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);scrollbar-width:none}.day-rail::-webkit-scrollbar{display:none}.day-pill{flex:0 0 auto;min-width:96px;padding:10px 12px;border:1px solid rgba(31,77,87,.16);border-radius:999px;background:#ffffffbd;color:var(--tile-blue);text-align:left;box-shadow:0 8px 22px #1c25260f}.day-pill span,.day-pill strong{display:block}.day-pill span{color:var(--muted);font-size:.72rem;font-weight:800}.day-pill strong{margin-top:2px;font-size:.9rem}.day-pill.active{background:var(--tile-blue);border-color:var(--tile-blue);color:#fff}.day-pill.active span{color:#ffffffc2}.content{width:min(100%,980px);margin:0 auto;padding:18px 14px 32px}.day-overview{display:grid;grid-template-columns:1fr;gap:16px;padding:18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.day-overview h2{margin:6px 0 10px;font-size:1.55rem;line-height:1.12;letter-spacing:0}.day-meta,.location-link{display:inline-flex;align-items:center;gap:6px;color:var(--tile-blue)}.day-meta-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px}.day-meta{margin:0;font-weight:800}.day-mood{display:inline-flex;width:fit-content;max-width:100%;margin:0;padding:6px 9px;border-radius:999px;background:#c8933429;color:#71500f;font-size:.86rem;font-weight:850;overflow-wrap:anywhere}.day-note,.activity-notes{color:var(--muted);line-height:1.55}.day-note{margin:10px 0 0}.day-actions,.activity-actions{display:flex;flex-wrap:wrap;gap:9px;align-items:center}.primary-button,.secondary-button,.ghost-button,.danger-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border-radius:var(--radius);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.primary-button:active,.secondary-button:active,.ghost-button:active,.danger-button:active,.icon-button:active{transform:translateY(1px)}.primary-button{width:100%;padding:0 16px;background:var(--tile-blue);color:#fff;font-weight:850;box-shadow:0 14px 28px #1f4d5747}.primary-button:disabled{cursor:not-allowed;opacity:.55}.secondary-button{padding:0 14px;background:#e8f1ee;color:var(--tile-blue);font-weight:850}.ghost-button{min-height:36px;padding:0 10px;background:#1f4d5714;color:var(--tile-blue);font-weight:800}.danger-button{padding:0 12px;background:#b2445d1f;color:#9d2443;font-weight:850}.danger-text{color:#9d2443}.icon-button{width:42px;padding:0;background:#1f4d5717;color:var(--tile-blue)}.icon-button.glass{background:#ffffff2e;color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.quick-strip{display:flex;align-items:center;gap:8px;padding:14px 0 4px;overflow-x:auto;color:var(--tile-blue);scrollbar-width:none}.quick-strip::-webkit-scrollbar{display:none}.quick-strip span{background:#ffffffc7;border:1px solid var(--line);color:var(--tile-blue);font-weight:800;box-shadow:0 8px 18px #1c25260f}.quick-strip .quick-label{border-color:transparent;background:transparent;color:var(--muted);box-shadow:none;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem}.timeline{position:relative;display:grid;gap:14px;margin-top:14px;padding-left:18px}.timeline:before{content:"";position:absolute;left:6px;top:10px;bottom:10px;width:2px;background:linear-gradient(var(--tile-blue),rgba(31,77,87,.08))}.activity-card{position:relative;padding:15px;border:1px solid rgba(31,77,87,.16);border-left:5px solid var(--terracotta);border-radius:var(--radius);background:#ffffffeb;box-shadow:0 12px 30px #1c25261a}.activity-card.done{border-color:#17633ab3;border-left-color:#17633a;background:linear-gradient(90deg,#17633a24,#17633a08 58%),#f7fff7;box-shadow:0 14px 32px #17633a2e}.time-dot{position:absolute;left:-18px;top:22px;width:13px;height:13px;border:3px solid #f6f2ea;border-radius:50%;background:var(--terracotta);box-shadow:0 0 0 2px #a94d352e}.activity-card.done .time-dot{background:#17633a;box-shadow:0 0 0 3px #17633a40}.activity-topline,.activity-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.activity-title-row{margin-top:10px}.activity-card.done .activity-title-row h3{color:#123c27;text-decoration:line-through;text-decoration-thickness:2px;text-decoration-color:#17633a8c}.activity-title-row h3{min-width:0;margin:0;color:var(--ink);font-size:1.12rem;line-height:1.25;letter-spacing:0;overflow-wrap:anywhere}.time-chip,.category-chip{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:5px 9px;border-radius:999px;font-size:.82rem;font-weight:850;white-space:nowrap}.time-chip{color:var(--tile-blue);background:#1f4d5717}.activity-badges{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px}.done-chip{display:inline-flex;align-items:center;gap:5px;min-height:30px;padding:5px 10px;border-radius:999px;background:#17633a;color:#fff;font-size:.82rem;font-weight:900;white-space:nowrap}.done-toggle{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:46px;height:46px;border:2px solid rgba(31,77,87,.18);border-radius:999px;background:#fff;color:var(--tile-blue);cursor:pointer;box-shadow:0 8px 18px #1c252614}.done-toggle.active{border-color:#17633a;background:#17633a;color:#fff;box-shadow:0 10px 20px #17633a47}.category-chip{color:#fff;background:var(--tile-blue)}.category-chip.food{background:var(--terracotta)}.category-chip.sight{background:var(--tile-blue-2)}.category-chip.travel,.category-chip.booking{background:var(--rose)}.category-chip.stay{background:var(--palm)}.category-chip.free{background:var(--ochre);color:#22190a}.location-link{margin-top:10px;text-decoration:none;font-weight:750;overflow-wrap:anywhere}.activity-notes{margin:10px 0 0}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin:14px 0}.photo-grid.compact{grid-template-columns:repeat(4,1fr);margin-bottom:12px}.photo-tile{position:relative;width:100%;aspect-ratio:1;overflow:hidden;border-radius:7px;background:#1f4d5714;cursor:pointer}.photo-tile img{width:100%;height:100%;object-fit:cover;display:block}.empty-state,.alert,.upload-banner{border-radius:var(--radius);border:1px solid var(--line);background:#ffffffd1;color:var(--muted)}.empty-state{padding:22px;text-align:center}.alert,.upload-banner{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:12px;font-weight:800}.alert{color:#9d2443;border-color:#b2445d3d}.upload-banner{color:var(--tile-blue)}.gate{min-height:100vh;display:grid;grid-template-rows:minmax(260px,42vh) 1fr;background:#172a2b}.gate-visual{background-image:linear-gradient(180deg,#0c16181f,#0c1618ad),url(/morocco-cover.png);background-size:cover;background-position:center}.gate-panel{margin-top:-38px;padding:24px 18px calc(28px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0;background:var(--paper)}.gate-lock{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;background:var(--tile-blue);color:#fff}label{display:grid;gap:7px;margin:14px 0;color:var(--ink);font-size:.88rem;font-weight:850}input,textarea,select{width:100%;border:1px solid rgba(31,77,87,.2);border-radius:var(--radius);background:#fff;color:var(--ink);outline:none}input,select{min-height:46px;padding:0 12px}textarea{min-height:100px;resize:vertical;padding:12px}input:focus,textarea:focus,select:focus{border-color:var(--tile-blue);box-shadow:0 0 0 3px #1f4d5724}.form-error{margin:8px 0 12px;color:#9d2443;font-weight:800}.modal-backdrop,.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20}.modal-backdrop{display:flex;align-items:flex-end;background:#0b13128a}.activity-modal{width:100%;max-height:92vh;overflow-y:auto;padding:18px;border-radius:20px 20px 0 0;background:var(--paper);box-shadow:0 -18px 50px #0b131247}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.modal-header h2{margin:4px 0 0;font-size:1.4rem;letter-spacing:0}.lightbox{display:grid;grid-template-rows:1fr auto;background:#070c0df2}.lightbox img{width:100%;height:100%;object-fit:contain;padding:54px 8px 8px}.lightbox-close{position:absolute;top:calc(12px + env(safe-area-inset-top));right:12px;background:#ffffff24;color:#fff}.lightbox-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px calc(12px + env(safe-area-inset-bottom));color:#fff;background:#ffffff14}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(min-width:720px){.hero{min-height:360px;padding:34px}.hero-copy h1{font-size:3.1rem}.content{padding:24px}.day-overview{grid-template-columns:1fr auto;align-items:end}.photo-grid,.photo-grid.compact{grid-template-columns:repeat(6,1fr)}.activity-modal{width:min(560px,calc(100% - 32px));margin:auto auto 24px;border-radius:16px}.gate{grid-template-columns:minmax(0,1fr) 460px;grid-template-rows:1fr}.gate-panel{margin:0;border-radius:0;align-self:stretch;display:flex;flex-direction:column;justify-content:center;padding:42px}}
