@import"https://fonts.googleapis.com/css2?family=Amiri:ital,wght@0,400;0,700;1,400;1,700&family=Cairo:wght@300;400;500;600;700;800&family=Playfair+Display:ital,wght@0,400..900;1,400..900&family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-terracotta: #D35E35;--color-terracotta-hover: #E77248;--color-terracotta-dark: #A23E1C;--color-terracotta-light: #FBF4F0;--color-chefchaouen: #1E6BA7;--color-chefchaouen-hover: #298AD4;--color-chefchaouen-dark: #124A75;--color-chefchaouen-light: #EBF3F8;--color-gold: #C29A38;--color-gold-hover: #DBB557;--color-gold-dark: #917122;--color-gold-light: #FAF4E5;--color-sand: #FAF5F0;--color-cream: #FFFDFB;--color-charcoal: #2A211E;--color-charcoal-light: #524743;--color-border: #E8DFD8;--font-serif: "Playfair Display", serif;--font-sans: "Inter", sans-serif;--font-arabic-serif: "Amiri", serif;--font-arabic-sans: "Cairo", sans-serif;--transition-smooth: all .3s cubic-bezier(.4, 0, .2, 1);--border-radius-sm: 8px;--border-radius-md: 16px;--border-radius-lg: 24px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--color-sand);color:var(--color-charcoal);font-family:var(--font-sans);line-height:1.6;-webkit-font-smoothing:antialiased;padding-top:82px}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--color-sand)}::-webkit-scrollbar-thumb{background:var(--color-terracotta-dark);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--color-terracotta)}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 24px}header{background-color:var(--color-cream);border-bottom:2px solid var(--color-border);position:sticky;top:0;z-index:100;box-shadow:0 4px 20px #2a211e08}.header-inner{display:flex;justify-content:space-between;align-items:center;height:80px}.logo-section{display:flex;flex-direction:column}.app-logo{font-family:var(--font-serif);font-size:24px;font-weight:800;letter-spacing:2px;color:var(--color-terracotta-dark);text-decoration:none;display:flex;align-items:center;gap:8px}.app-logo span{font-family:var(--font-arabic-serif);font-size:26px;color:var(--color-chefchaouen-dark);font-weight:700}.logo-sub{font-family:var(--font-sans);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--color-charcoal-light);margin-top:-2px;font-weight:600}.nav-controls{display:flex;align-items:center;gap:16px}.color-swatch-badge{display:flex;align-items:center;gap:6px;background:var(--color-terracotta-light);padding:6px 12px;border-radius:30px;font-size:11px;font-weight:600;color:var(--color-terracotta-dark);border:1px solid rgba(211,94,53,.15)}@media(max-width:640px){.color-swatch-badge{display:none}}.color-dots{display:flex;gap:4px}.dot{width:12px;height:12px;border-radius:50%;display:inline-block;cursor:pointer;transition:transform .2s ease}.dot:hover{transform:scale(1.3)}.dot.terracotta{background-color:var(--color-terracotta)}.dot.blue{background-color:var(--color-chefchaouen)}.dot.gold{background-color:var(--color-gold)}.lang-switch-btn{background:var(--color-cream);border:1px solid var(--color-border);padding:8px 16px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;color:var(--color-charcoal);transition:var(--transition-smooth)}.lang-switch-btn:hover{background:var(--color-terracotta-light);border-color:var(--color-terracotta);color:var(--color-terracotta-dark)}.global-hero{position:relative;background-size:cover;background-position:center;border-radius:var(--border-radius-lg);overflow:hidden;margin:24px 0 32px;box-shadow:0 15px 35px #2a211e1f}.global-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#2a211ee6,#2a211e80 70%,#d35e354d);z-index:1}.global-hero-motif{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.08;background-image:radial-gradient(var(--color-gold) 1px,transparent 0),radial-gradient(var(--color-gold) 1px,transparent 0);background-size:24px 24px;background-position:0 0,12px 12px;z-index:2;pointer-events:none}.global-hero-inner{position:relative;z-index:3;padding:80px 48px;display:flex;flex-direction:column;align-items:center;text-align:center}@media(max-width:640px){.global-hero-inner{padding:48px 24px}}.global-hero-tagline{font-size:13px;font-weight:800;letter-spacing:4px;text-transform:uppercase;color:var(--color-gold);margin-bottom:12px}.global-hero-title{font-family:var(--font-serif);font-size:48px;font-weight:900;color:#fff;line-height:1.1;max-width:800px;margin-bottom:20px}.global-hero-title span{font-family:var(--font-arabic-serif);color:var(--color-gold);display:inline-block;font-size:56px;margin-right:12px}.global-hero-desc{color:#ffffffe6;max-width:650px;font-size:16px;line-height:1.7;margin-bottom:36px}.cta-group{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;width:100%}.btn-primary-ai{background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-terracotta) 100%);color:#fff;border:none;font-weight:700;padding:14px 28px;border-radius:30px;font-size:15px;cursor:pointer;display:inline-flex;align-items:center;gap:10px;box-shadow:0 4px 15px #d35e3566;transition:var(--transition-smooth)}.btn-primary-ai:hover{transform:translateY(-3px);box-shadow:0 8px 25px #d35e3599}.search-container{background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);border-radius:50px;padding:6px 12px 6px 24px;display:flex;align-items:center;gap:12px;width:100%;max-width:500px;margin-top:16px;transition:var(--transition-smooth)}.search-container:focus-within{background:#fff;box-shadow:0 10px 25px #00000026;border-color:var(--color-terracotta)}.search-icon{color:var(--color-gold)}.search-input{background:transparent;border:none;outline:none;color:#fff;font-size:15px;width:100%;font-weight:500}.search-container:focus-within .search-input{color:var(--color-charcoal)}.search-input::placeholder{color:#ffffffb3}.search-container:focus-within .search-input::placeholder{color:var(--color-charcoal-light)}.search-clear-btn{background:none;border:none;color:var(--color-charcoal-light);cursor:pointer;display:none}.featured-section-header{margin-bottom:20px;display:flex;justify-content:space-between;align-items:flex-end;border-bottom:2px solid var(--color-border);padding-bottom:12px}.featured-section-title{font-family:var(--font-serif);font-size:28px;font-weight:800;color:var(--color-terracotta-dark)}.featured-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:48px}.city-card{background-color:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--border-radius-md);overflow:hidden;cursor:pointer;transition:var(--transition-smooth);position:relative;display:flex;flex-direction:column}.city-card:hover{transform:translateY(-8px);box-shadow:0 15px 30px #2a211e14}.city-card.active-marrakech{border-color:var(--color-terracotta);box-shadow:0 0 0 3px #d35e3526,0 10px 25px #d35e3514}.city-card.active-chefchaouen{border-color:var(--color-chefchaouen);box-shadow:0 0 0 3px #1e6ba726,0 10px 25px #1e6ba714}.city-card.active-fez{border-color:var(--color-gold);box-shadow:0 0 0 3px #c29a3826,0 10px 25px #c29a3814}.city-card.active-essaouira{border-color:#2ec4b6;box-shadow:0 0 0 3px #2ec4b626,0 10px 25px #2ec4b614}.city-card-cover-frame{height:180px;width:100%;overflow:hidden;position:relative}.city-card-img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.city-card:hover .city-card-img{transform:scale(1.08)}.city-card-badge{position:absolute;top:12px;right:12px;background-color:var(--color-gold);color:var(--color-charcoal);font-weight:700;font-size:11px;padding:4px 10px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;z-index:10}.city-card-body{padding:20px;flex-grow:1}.city-card-name{font-family:var(--font-serif);font-size:22px;font-weight:800;color:var(--color-charcoal);display:flex;justify-content:space-between;align-items:center}.city-card-ar-name{font-family:var(--font-arabic-serif);font-size:20px;color:var(--color-gold-dark)}.city-card-region{font-size:12px;font-weight:600;color:var(--color-charcoal-light);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.city-card-note{font-size:13px;color:var(--color-charcoal-light);margin-top:12px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.city-card-footer{padding:16px 20px;border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.city-card-link-text{font-size:13px;font-weight:700;color:var(--color-terracotta)}.city-card-days{font-size:12px;font-weight:700;color:var(--color-charcoal-light)}.ai-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#2a211eb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:200;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;padding:20px}.ai-modal-backdrop.modal-open{display:flex;opacity:1}.ai-modal{background-color:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #2a211e40;transform:translateY(20px);transition:transform .3s cubic-bezier(.175,.885,.32,1.275);position:relative}.ai-modal-backdrop.modal-open .ai-modal{transform:translateY(0)}.ai-modal:after{content:"";position:absolute;top:12px;left:12px;right:12px;bottom:12px;border:1px solid rgba(194,154,56,.15);pointer-events:none;border-radius:calc(var(--border-radius-lg) - 10px);z-index:1}.ai-modal-header{background-color:var(--color-sand);padding:24px 32px;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;position:relative;z-index:5}.ai-modal-title{font-family:var(--font-serif);font-size:24px;font-weight:800;color:var(--color-terracotta-dark);display:flex;align-items:center;gap:10px}.ai-modal-title span{font-family:var(--font-arabic-serif);color:var(--color-gold);font-size:26px}.close-modal-btn{background:none;border:none;color:var(--color-charcoal-light);cursor:pointer;padding:4px;border-radius:50%;transition:var(--transition-smooth)}.close-modal-btn:hover{background-color:var(--color-border);color:var(--color-charcoal)}.ai-modal-content{padding:32px;overflow-y:auto;position:relative;z-index:5;display:grid;grid-template-columns:1fr 1.2fr;gap:32px}@media(max-width:768px){.ai-modal-content{grid-template-columns:1fr;gap:24px;padding:24px}}.planner-form{display:flex;flex-direction:column;gap:20px}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--color-charcoal-light);letter-spacing:.5px}.form-select,.form-input-text{background-color:#fff;border:1px solid var(--color-border);padding:10px 14px;border-radius:var(--border-radius-sm);font-size:14px;font-family:var(--font-sans);color:var(--color-charcoal);outline:none;transition:var(--transition-smooth);width:100%}.form-select:focus,.form-input-text:focus{border-color:var(--color-terracotta);box-shadow:0 0 0 3px #d35e351a}.interests-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.interest-pill{border:1px solid var(--color-border);background-color:#fff;border-radius:8px;padding:8px 12px;font-size:12px;font-weight:600;color:var(--color-charcoal-light);cursor:pointer;text-align:center;transition:var(--transition-smooth);-webkit-user-select:none;user-select:none}.interest-pill.selected{background-color:var(--color-chefchaouen-light);border-color:var(--color-chefchaouen);color:var(--color-chefchaouen-dark)}.planner-output-panel{background-color:var(--color-sand);border-radius:var(--border-radius-md);border:1px solid var(--color-border);padding:24px;display:flex;flex-direction:column;height:100%;min-height:350px;max-height:550px;overflow:hidden}.output-scroll-body{flex-grow:1;overflow-y:auto;font-size:14px;line-height:1.6}.output-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:100%;color:var(--color-charcoal-light);gap:16px}.output-placeholder-logo{color:var(--color-gold)}.spinner-container{display:none;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:100%;text-align:center}.morocco-spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-gold);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-message{font-size:13px;font-weight:700;color:var(--color-gold-dark);letter-spacing:.5px;text-transform:uppercase}.markdown-body{color:var(--color-charcoal)}.markdown-body h1,.markdown-body h2,.markdown-body h3{font-family:var(--font-serif);color:var(--color-terracotta-dark);margin:16px 0 10px;font-weight:800}.markdown-body h1{font-size:22px;border-bottom:1px solid var(--color-border);padding-bottom:6px}.markdown-body h2{font-size:18px}.markdown-body h3{font-size:15px}.markdown-body ul,.markdown-body ol{padding-left:20px;margin-bottom:14px}.markdown-body li{margin-bottom:4px}.markdown-body p{margin-bottom:14px}.markdown-body code{font-family:monospace;background-color:var(--color-border);padding:2px 4px;border-radius:4px}.output-actions{display:none;gap:12px;margin-top:16px}.btn-secondary{background-color:#fff;border:1px solid var(--color-border);padding:10px 18px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;color:var(--color-charcoal);transition:var(--transition-smooth)}.btn-secondary:hover{background-color:var(--color-sand);border-color:var(--color-charcoal-light)}.hero-wrapper{margin:24px 0;position:relative;overflow:hidden;border-radius:var(--border-radius-lg);box-shadow:0 10px 30px #2a211e14}.hero-cover{position:relative;width:100%;height:420px;background-size:cover;background-position:center;display:flex;align-items:flex-end;color:#fff;transition:background-image .5s ease-in-out}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#120c0ae6,#120c0a66,#120c0a1a);z-index:1}.hero-content{position:relative;z-index:2;padding:40px;width:100%}.hero-meta-badge{background:var(--color-gold);color:var(--color-charcoal);padding:4px 12px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;display:inline-block;margin-bottom:12px}.hero-title-container{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px}.hero-title{font-family:var(--font-serif);font-size:52px;font-weight:900;line-height:1.1;letter-spacing:-1px}.hero-title-arabic{font-family:var(--font-arabic-serif);font-size:64px;color:var(--color-gold);line-height:1;text-shadow:0 2px 10px rgba(0,0,0,.5)}.hero-subtitle{font-family:var(--font-sans);font-size:14px;opacity:.9;letter-spacing:4px;text-transform:uppercase;margin-top:6px}.explorer-grid{display:grid;grid-template-columns:1.1fr 1.9fr;gap:32px;margin-bottom:48px}@media(max-width:968px){.explorer-grid{grid-template-columns:1fr}}.sidebar-panel{display:flex;flex-direction:column;gap:24px}.card-frame{background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--border-radius-md);padding:32px;box-shadow:0 4px 15px #2a211e05;position:relative}.card-frame:before{content:"";position:absolute;top:8px;left:8px;right:8px;bottom:8px;border:1px solid rgba(194,154,56,.15);pointer-events:none;border-radius:calc(var(--border-radius-md) - 6px)}.card-title{font-family:var(--font-serif);font-size:24px;font-weight:700;color:var(--color-terracotta-dark);margin-bottom:24px;padding-bottom:12px;border-bottom:2px solid var(--color-sand);display:flex;align-items:center;justify-content:space-between}.card-title span.title-ar{font-family:var(--font-arabic-serif);font-size:22px;color:var(--color-gold-dark)}.meta-list{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.meta-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-sand);border-radius:var(--border-radius-sm);border-left:4px solid var(--color-chefchaouen)}.meta-label{font-size:13px;font-weight:600;color:var(--color-charcoal-light);text-transform:uppercase;letter-spacing:.5px}.meta-value{font-size:15px;font-weight:700;color:var(--color-charcoal)}.cultural-note-box{background-color:var(--color-gold-light);border-radius:var(--border-radius-sm);padding:20px;border-left:4px solid var(--color-gold);margin-top:16px}.cultural-note-header{font-family:var(--font-sans);font-weight:700;font-size:14px;color:var(--color-gold-dark);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;display:flex;align-items:center;gap:8px}.cultural-note-text{font-size:14px;color:var(--color-charcoal-light);font-style:italic;line-height:1.6}.currency-widget{background:var(--color-chefchaouen-light);border-left:4px solid var(--color-chefchaouen)}.currency-widget .card-title{color:var(--color-chefchaouen-dark)}.calculator-body{display:flex;flex-direction:column;gap:16px}.calculator-row{display:flex;flex-direction:column;gap:6px}.calc-label{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--color-chefchaouen-dark)}.calc-input-wrapper{display:flex;align-items:center;background:#fff;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);padding:10px 16px}.calc-symbol{font-weight:700;color:var(--color-charcoal-light);width:40px}.calc-input{border:none;background:transparent;width:100%;font-size:18px;font-weight:700;color:var(--color-charcoal);outline:none}.calc-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--color-border);outline:none}.calc-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-chefchaouen);cursor:pointer;transition:transform .1s ease}.calc-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.main-stage{display:flex;flex-direction:column;gap:32px}.section-label{font-family:var(--font-sans);font-size:11px;font-weight:800;letter-spacing:2.5px;color:var(--color-terracotta-dark);text-transform:uppercase;margin-bottom:8px;display:flex;align-items:center;gap:8px}.section-label:after{content:"";flex:1;height:1.5px;background-color:var(--color-border)}.attractions-list{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:640px){.attractions-list{grid-template-columns:1fr}}.attraction-card{background:var(--color-cream);border-radius:var(--border-radius-md);overflow:hidden;border:1px solid var(--color-border);box-shadow:0 4px 15px #2a211e08;transition:var(--transition-smooth);display:flex;flex-direction:column}.attraction-card:hover{transform:translateY(-8px);box-shadow:0 12px 25px #2a211e14;border-color:var(--color-terracotta)}.attraction-img-frame{height:200px;overflow:hidden;position:relative}.attraction-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.attraction-card:hover .attraction-img{transform:scale(1.1)}.attraction-info{padding:24px;flex-grow:1;display:flex;flex-direction:column}.attraction-name{font-family:var(--font-serif);font-size:20px;font-weight:700;color:var(--color-charcoal);margin-bottom:12px}.attraction-desc{font-size:14px;color:var(--color-charcoal-light);line-height:1.6}.hotel-card{background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--border-radius-md);padding:32px;position:relative}.hotel-toggle-row{display:flex;background:var(--color-sand);padding:6px;border-radius:30px;gap:4px;margin-bottom:24px;width:fit-content;border:1px solid var(--color-border)}.hotel-toggle-btn{background:transparent;border:none;padding:8px 18px;border-radius:20px;font-size:13px;font-weight:700;cursor:pointer;color:var(--color-charcoal-light);transition:var(--transition-smooth)}.hotel-toggle-btn.active{background:var(--color-terracotta);color:#fff;box-shadow:0 4px 10px #d35e3540}.hotel-display{display:flex;gap:32px;align-items:center}@media(max-width:580px){.hotel-display{flex-direction:column;align-items:flex-start}}.hotel-details{flex:1}.hotel-tier{font-size:11px;font-weight:800;color:var(--color-gold-dark);text-transform:uppercase;letter-spacing:2px;margin-bottom:6px}.hotel-name{font-family:var(--font-serif);font-size:28px;font-weight:800;color:var(--color-charcoal);margin-bottom:12px}.hotel-amenity{font-size:14px;color:var(--color-charcoal-light);background:var(--color-sand);padding:10px 16px;border-radius:8px;display:inline-flex;align-items:center;gap:8px;border-left:3px solid var(--color-gold)}.hotel-price-badge{text-align:right;background:var(--color-terracotta-light);border:1px solid rgba(211,94,53,.2);padding:16px 24px;border-radius:var(--border-radius-sm);display:flex;flex-direction:column;justify-content:center}@media(max-width:580px){.hotel-price-badge{text-align:left;width:100%}}.hotel-price-val{font-family:var(--font-serif);font-size:32px;font-weight:900;color:var(--color-terracotta-dark);line-height:1.1}.hotel-price-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-charcoal-light)}.transit-board{display:flex;flex-direction:column;gap:16px}.transit-item{background:var(--color-cream);border:1px solid var(--color-border);padding:20px 24px;border-radius:var(--border-radius-sm);display:flex;justify-content:space-between;align-items:center;gap:16px;transition:var(--transition-smooth)}.transit-item:hover{border-color:var(--color-chefchaouen);background:var(--color-cream);box-shadow:0 4px 12px #1e6ba70d}.transit-left{display:flex;align-items:center;gap:16px}.transit-icon-avatar{width:44px;height:44px;border-radius:50%;background:var(--color-chefchaouen-light);display:flex;justify-content:center;align-items:center;color:var(--color-chefchaouen-dark);flex-shrink:0}.transit-name{font-family:var(--font-serif);font-size:18px;font-weight:700;color:var(--color-charcoal)}.transit-desc{font-size:13px;color:var(--color-charcoal-light);margin-top:2px}.transit-fare{text-align:right;background:var(--color-chefchaouen-light);padding:8px 16px;border-radius:4px;font-size:13px;font-weight:700;color:var(--color-chefchaouen-dark);border:1px solid rgba(30,107,167,.15);flex-shrink:0}@media(max-width:580px){.transit-item{flex-direction:column;align-items:flex-start}.transit-fare{text-align:left;width:100%}}.itinerary-board{background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--border-radius-md);padding:32px}.itinerary-timeline{display:flex;flex-direction:column;gap:24px;margin-top:16px}.timeline-step{display:flex;gap:20px;position:relative}.timeline-step:not(:last-child):after{content:"";position:absolute;left:20px;top:40px;bottom:-16px;width:2px;background:var(--color-border)}.timeline-idx{width:40px;height:40px;border-radius:50%;background:var(--color-terracotta);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;box-shadow:0 4px 10px #d35e3533;flex-shrink:0;font-family:var(--font-serif)}.timeline-content{flex:1}.timeline-day{font-size:12px;font-weight:800;text-transform:uppercase;color:var(--color-terracotta-dark);letter-spacing:1px}.timeline-title{font-family:var(--font-serif);font-size:18px;font-weight:700;color:var(--color-charcoal);margin-bottom:6px}.timeline-desc{font-size:14px;color:var(--color-charcoal-light)}footer{margin-top:64px;border-top:2px solid var(--color-border);background-color:var(--color-cream);padding:48px 0}.footer-credits{text-align:center;font-size:13px;color:var(--color-charcoal-light)}.schema-explorer-card{background:#1e1917;color:#dfd7d3;margin-top:48px;border-radius:var(--border-radius-md);border:1px solid #362f2c;overflow:hidden;box-shadow:0 10px 30px #00000026}.schema-header{background:#171312;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #362f2c}.schema-title-wrapper{display:flex;align-items:center;gap:12px}.schema-indicator{width:10px;height:10px;background-color:#2ec4b6;border-radius:50%;box-shadow:0 0 8px #2ec4b6}.schema-title{font-family:var(--font-sans);font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:#fff}.schema-actions{display:flex;align-items:center;gap:16px}.validation-tag{background:#2ec4b626;color:#2ec4b6;border:1px solid rgba(46,196,182,.3);padding:4px 10px;border-radius:4px;font-size:11px;font-weight:700}.schema-body{padding:24px;font-family:Courier New,Courier,monospace}.schema-desc{font-size:12px;color:#9f918c;margin-bottom:16px;font-family:var(--font-sans)}.json-preview-frame{background:#151110;border:1px solid #282220;border-radius:var(--border-radius-sm);padding:20px;overflow-x:auto;font-size:13px;line-height:1.5;color:#0fc;max-height:400px}[dir=rtl]{font-family:var(--font-arabic-sans)}[dir=rtl] .app-logo{flex-direction:row-reverse}[dir=rtl] .meta-item{border-left:none;border-right:4px solid var(--color-chefchaouen)}[dir=rtl] .cultural-note-box{border-left:none;border-right:4px solid var(--color-gold)}[dir=rtl] .transit-icon-avatar{margin-left:0}[dir=rtl] .hotel-amenity{border-left:none;border-right:3px solid var(--color-gold)}[dir=rtl] .section-label:after{display:none}[dir=rtl] .section-label:before{content:"";flex:1;height:1.5px;background-color:var(--color-border)}.desktop-nav{display:flex;align-items:center;gap:16px}.mobile-nav-bar{display:none;align-items:center;gap:12px}.hamburger-btn{background:var(--color-terracotta-light);color:var(--color-terracotta-dark);border:2px solid rgba(211,94,53,.15);border-radius:var(--border-radius-md);width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth)}.hamburger-btn:hover{background:var(--color-terracotta);color:#fff}.mobile-nav-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#2a211efa;z-index:9999;display:flex;flex-direction:column;padding:40px 24px;box-sizing:border-box;opacity:0;pointer-events:none;transform:translateY(-20px);transition:opacity .3s ease,transform .3s ease}.mobile-nav-overlay.open{opacity:1;pointer-events:auto;transform:translateY(0)}.mobile-nav-overlay-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}.mobile-nav-overlay-logo{font-family:var(--font-serif);font-size:24px;font-weight:800;letter-spacing:2px;color:var(--color-terracotta);text-decoration:none}.mobile-nav-overlay-logo span{font-family:var(--font-arabic-serif);font-size:26px;color:var(--color-gold);margin-left:6px}.close-overlay-btn{background:#ffffff1a;color:#fff;border:none;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth)}.close-overlay-btn:hover{background:#fff3}.mobile-nav-links{display:flex;flex-direction:column;gap:16px}.mobile-nav-link{font-family:var(--font-serif);font-size:20px;color:#fff;text-decoration:none;padding:14px 18px;border-radius:var(--border-radius-md);background:#ffffff08;border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:16px;transition:var(--transition-smooth)}.mobile-nav-link:hover{background:var(--color-terracotta);border-color:var(--color-terracotta-hover);padding-left:24px}.cookie-banner{position:fixed;bottom:24px;left:24px;right:24px;background-color:var(--color-charcoal);color:#fff;padding:20px 24px;border-radius:var(--border-radius-md);box-shadow:0 10px 40px #0000004d;z-index:10000;display:flex;align-items:center;justify-content:space-between;gap:20px;border:1px solid rgba(255,255,255,.1);animation:slideBannerUp .4s cubic-bezier(.4,0,.2,1)}@keyframes slideBannerUp{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-text{font-size:13px;line-height:1.6;color:#dfd7d4;margin:0;flex:1}.cookie-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.btn-cookie-accept{background-color:var(--color-terracotta);color:#fff;border:none;padding:10px 18px;border-radius:var(--border-radius-sm);font-weight:700;font-size:12px;cursor:pointer;transition:var(--transition-smooth);white-space:nowrap}.btn-cookie-accept:hover{background-color:var(--color-terracotta-hover)}.btn-cookie-privacy{background-color:transparent;color:#dfd7d4;border:1px solid rgba(255,255,255,.2);padding:10px 18px;border-radius:var(--border-radius-sm);font-weight:600;font-size:12px;cursor:pointer;transition:var(--transition-smooth);text-decoration:none;white-space:nowrap}.btn-cookie-privacy:hover{background:#ffffff1a;color:#fff}.site-footer{background-color:var(--color-charcoal);color:#f5efeb;padding:64px 0 32px;border-top:4px solid var(--color-terracotta);margin-top:80px}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;max-width:1200px;margin:0 auto;padding:0 24px}.footer-col{display:flex;flex-direction:column;gap:16px}.footer-col h3,.footer-col h4{color:var(--color-gold);font-family:var(--font-serif),serif;font-size:18px;font-weight:700;margin-bottom:8px;letter-spacing:.5px}.footer-brand-title{display:flex;align-items:center;gap:10px;color:#fffdfb!important;font-size:22px!important;font-weight:800!important;text-decoration:none}.footer-tagline{font-size:14px;line-height:1.6;color:#c2b6b0;max-width:380px;margin-top:4px}.footer-social-links{display:flex;gap:12px;margin-top:12px}.footer-social-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--color-charcoal-light);color:#f5efeb;text-decoration:none;transition:var(--transition-smooth);border:1px solid rgba(232,223,216,.1)}.footer-social-icon:hover{background:var(--color-terracotta);color:#fffdfb;transform:translateY(-3px);box-shadow:0 4px 12px #d35e3540}.footer-nav-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.footer-nav-links a{color:#c2b6b0;text-decoration:none;font-size:14px;font-weight:500;transition:var(--transition-smooth);display:inline-flex;align-items:center;gap:6px}.footer-nav-links a:hover{color:var(--color-gold-hover);transform:translate(4px)}.footer-bottom-bar{border-top:1px solid rgba(232,223,216,.1);margin-top:48px;padding-top:24px;font-size:13px;color:#9c8e88}.footer-bottom-container{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}@media(max-width:768px){.footer-grid{grid-template-columns:1fr;gap:36px}.footer-bottom-container{flex-direction:column;text-align:center}.site-footer{padding:48px 0 24px}}@media(max-width:768px){.desktop-nav{display:none}.mobile-nav-bar{display:flex}.cookie-banner{flex-direction:column;align-items:stretch;bottom:12px;left:12px;right:12px;padding:16px;gap:16px;text-align:center}.cookie-actions{justify-content:center}}.nav-link-desktop{font-family:var(--font-sans),sans-serif;color:var(--color-charcoal);text-decoration:none;border-radius:var(--border-radius-sm);transition:var(--transition-smooth)}.nav-link-desktop:hover{color:var(--color-terracotta)!important;background-color:var(--color-cream)}.nav-link-desktop.highlighted-trip-planner:hover{background-color:#d35e3526!important;border-color:var(--color-terracotta)!important;transform:scale(1.02)}html{scroll-behavior:smooth;scroll-padding-top:100px;overflow-x:hidden;width:100%}body{overflow-x:hidden;width:100%}#app-header{position:fixed;top:0;left:0;width:100%;z-index:1000;transition:transform .3s cubic-bezier(.16,1,.3,1),background-color .3s ease,box-shadow .3s ease,backdrop-filter .3s ease}#app-header.header-hidden{transform:translateY(-100%)}#app-header.header-show{transform:translateY(0);background-color:#fdfbf9f5!important;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 20px #2a211e14}.city-card,.dir-card,.attraction-card,.transit-item,.btn-primary,.btn-secondary,.lang-btn{transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s cubic-bezier(.16,1,.3,1),border-color .3s ease,background-color .3s ease!important}.city-card:active,.dir-card:active,.attraction-card:active,.transit-item:active,.btn-primary:active,.btn-secondary:active,.lang-btn:active{transform:scale(.97)!important}.city-card-cover-frame,.dir-card-photo-wrapper,.attraction-img-frame{background-color:#f7f5f3;position:relative}.lazy-img{opacity:0;transition:opacity .4s ease-in-out}.lazy-img.loaded{opacity:1}.reveal-section{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);will-change:transform,opacity}.reveal-section.revealed{opacity:1;transform:translateY(0)}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;width:100%}.skeleton-card{background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--border-radius-md);padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:0 4px 15px #2a211e05;height:320px}.skeleton-media{height:160px;width:100%;border-radius:var(--border-radius-sm);background:linear-gradient(90deg,#f0eeee 25%,#f7f5f5,#f0eeee 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}.skeleton-block{height:16px;border-radius:4px;background:linear-gradient(90deg,#f0eeee 25%,#f7f5f5,#f0eeee 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}.skeleton-title{width:60%;height:22px}.skeleton-text-lg{width:85%;height:14px}.skeleton-text-sm{width:45%;height:12px}@media(max-width:768px){.skeleton-grid{grid-template-columns:repeat(2,1fr)!important;gap:12px!important}.skeleton-card{min-height:190px!important;height:auto!important;padding:10px}.skeleton-media{height:90px!important}.skeleton-title{height:16px}}@media(max-width:768px){.featured-grid,#featured-cities-grid{grid-template-columns:repeat(2,1fr)!important;gap:12px!important;padding:0;margin-bottom:24px!important;box-sizing:border-box!important}.attractions-list,#attractions-grid,.dir-grid,#cities-directory-grid{grid-template-columns:repeat(2,1fr)!important;gap:12px!important;box-sizing:border-box!important}.city-card,.dir-card,.attraction-card{border-radius:var(--border-radius-sm)!important;min-height:190px!important;height:auto!important;display:flex!important;flex-direction:column!important;justify-content:space-between!important;overflow:hidden!important;border:1px solid var(--color-border)!important;box-shadow:0 2px 8px #2a211e05!important;padding-bottom:4px!important;box-sizing:border-box!important}.city-card-cover-frame,.dir-card-photo-wrapper,.attraction-img-frame{height:90px!important;min-height:90px!important;aspect-ratio:auto!important}.city-card-body,.dir-card-body,.attraction-info{padding:8px!important;flex-grow:1!important;display:flex!important;flex-direction:column!important;overflow:visible!important}.city-card-name,.dir-card-title,.attraction-name{font-size:13px!important;font-weight:700!important;line-height:1.2!important;margin-bottom:2px!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.city-card-region,.dir-card-region,.attraction-desc{font-size:11px!important;line-height:1.2!important;margin-top:0!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.city-card-note,.dir-card-desc{display:none!important}.city-card-footer,.dir-card-footer{padding:6px 8px!important;font-size:10px!important;border-top:1px solid var(--color-border)!important;background:#fffefd!important;margin-top:auto!important}.city-card-link-text{font-size:9px!important}.container{padding-left:16px!important;padding-right:16px!important;box-sizing:border-box!important}section{padding:24px 0!important}}
