@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&family=Amiri:wght@400;700&display=swap";.moro-pattern{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.moro-pattern--star{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpolygon points='30,0 35,25 60,30 35,35 30,60 25,35 0,30 25,25' fill='%23C75B39' opacity='0.1'/%3E%3C/svg%3E");background-size:var(--pattern-size, 60px) var(--pattern-size, 60px);opacity:var(--pattern-opacity, .1)}.moro-pattern--zellige{position:absolute;top:0;right:0;bottom:0;left:0}.moro-border{width:100%;height:10px}.moro-arch-frame{position:relative;display:flex;flex-direction:column}.moro-arch-frame__top{height:40px;margin-bottom:-1px}.moro-arch-frame__top svg{display:block;width:100%;height:100%}.moro-arch-frame__content{flex:1;border:2px solid currentColor;border-top:none;border-radius:0 0 var(--radius-2xl) var(--radius-2xl);padding:var(--space-6)}.moro-orbs{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.moro-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.4}.moro-orb--terracotta{width:300px;height:300px;background:var(--color-terracotta);top:-100px;left:-100px}.moro-orb--saffron{width:250px;height:250px;background:var(--color-saffron);bottom:-80px;right:-80px}.moro-orb--blue{width:200px;height:200px;background:var(--color-deep-blue);top:50%;left:50%;transform:translate(-50%,-50%)}.moro-arabesque-corner{position:absolute}.moro-arabesque-corner--top-left{top:0;left:0}.moro-arabesque-corner--top-right{top:0;right:0}.moro-arabesque-corner--bottom-right{bottom:0;right:0}.moro-arabesque-corner--bottom-left{bottom:0;left:0}.moro-gradient-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#c75b390d,#e8a8380d,#1e4d6b0d);pointer-events:none}@keyframes patternShift{0%{background-position:0 0}to{background-position:60px 60px}}.moro-pattern--animated{animation:patternShift 20s linear infinite}@media (max-width: 768px){.moro-orb--terracotta{width:200px;height:200px}.moro-orb--saffron{width:180px;height:180px}.moro-orb--blue{width:150px;height:150px}}.moro-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-body);font-weight:var(--font-semibold);border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden;white-space:nowrap;-webkit-tap-highlight-color:transparent}.moro-btn:focus-visible{outline:2px solid var(--color-gold);outline-offset:2px}.moro-btn--sm{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);min-height:36px}.moro-btn--md{padding:var(--space-3) var(--space-6);font-size:var(--text-base);min-height:44px}.moro-btn--lg{padding:var(--space-4) var(--space-8);font-size:var(--text-lg);min-height:52px}.moro-btn--primary{background:var(--gradient-moroccan);color:#fff;box-shadow:var(--shadow-terracotta)}.moro-btn--primary:hover:not(:disabled){box-shadow:0 12px 40px #c75b3959}.moro-btn--secondary{background:var(--color-deep-blue);color:#fff;box-shadow:var(--shadow-md)}.moro-btn--secondary:hover:not(:disabled){background:var(--color-deep-blue-light)}.moro-btn--outline{background:transparent;color:var(--color-terracotta);border:2px solid var(--color-terracotta)}.moro-btn--outline:hover:not(:disabled){background:#c75b391a}.hero-section .moro-btn--outline,.cta-section .moro-btn--outline{color:#fff;border-color:#ffffffb3;background:#ffffff1a}.hero-section .moro-btn--outline:hover:not(:disabled),.cta-section .moro-btn--outline:hover:not(:disabled){background:#fff3;border-color:#fff}.moro-btn--ghost{background:transparent;color:var(--color-charcoal)}.moro-btn--ghost:hover:not(:disabled){background:#2d29260d}.moro-btn--gold{background:var(--gradient-sunset);color:#fff;box-shadow:var(--shadow-gold)}.moro-btn--success{background:var(--color-emerald);color:#fff}.moro-btn--danger{background:var(--color-terracotta);color:#fff}.moro-btn--full{width:100%}.moro-btn--disabled,.moro-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.moro-btn--loading{pointer-events:none}.moro-btn__spinner{display:flex;align-items:center;justify-content:center}.moro-btn--icon-only{padding:var(--space-2);border-radius:var(--radius-full)}.moro-btn--icon-only.moro-btn--sm{width:36px;height:36px}.moro-btn--icon-only.moro-btn--md{width:44px;height:44px}.moro-btn--icon-only.moro-btn--lg{width:52px;height:52px}.moro-btn__icon{display:flex;align-items:center;font-size:1.2em}.moro-btn__icon--left{margin-right:var(--space-1)}.moro-btn__icon--right{margin-left:var(--space-1)}.moro-btn--primary:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.moro-btn--primary:hover:after{left:100%}.landing-page{min-height:100vh;background:var(--color-cream);overflow-x:hidden}.hero-section{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-20) var(--space-6) var(--space-12);overflow:hidden}.hero-background{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--color-terracotta) 0%,var(--color-burnt-orange) 50%,var(--color-saffron) 100%)}.hero-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cpolygon points='40,0 50,35 80,40 50,45 40,80 30,45 0,40 30,35' fill='white' opacity='0.03'/%3E%3C/svg%3E");background-size:80px 80px;pointer-events:none}.hero-content{position:relative;z-index:10;text-align:center;max-width:800px;color:#fff}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);margin-bottom:var(--space-6)}.hero-title{font-family:var(--font-heading);font-size:clamp(3rem,12vw,5rem);font-weight:var(--font-bold);line-height:1;margin:0 0 var(--space-2) 0;letter-spacing:-.02em;text-shadow:0 4px 20px rgba(0,0,0,.2)}.hero-arabic{font-family:var(--font-arabic);font-size:var(--text-2xl);opacity:.8;margin:0 0 var(--space-4) 0;direction:rtl}.hero-tagline{font-family:var(--font-heading);font-size:clamp(1.2rem,4vw,1.6rem);font-weight:var(--font-medium);margin:0 0 var(--space-4) 0;opacity:.95}.hero-description{font-size:var(--text-lg);line-height:var(--leading-relaxed);opacity:.9;margin:0 auto var(--space-8) auto;max-width:600px}.hero-cta{display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:center;margin-bottom:var(--space-10)}.hero-stats{display:flex;align-items:center;justify-content:center;gap:var(--space-6);padding:var(--space-5);background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-2xl);border:1px solid rgba(255,255,255,.15)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.stat-number{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--font-bold)}.stat-label{font-size:var(--text-sm);opacity:.8}.stat-divider{width:1px;height:40px;background:#ffffff4d}.hero-monuments{position:absolute;bottom:120px;left:0;right:0;display:flex;justify-content:center;gap:var(--space-4);padding:0 var(--space-4);z-index:5}.monument-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);background:#fffffff2;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);cursor:pointer}.monument-icon{font-size:2rem}.monument-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-charcoal);white-space:nowrap}.scroll-indicator{position:absolute;bottom:var(--space-8);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:#fff;opacity:.7;font-size:var(--text-sm)}.scroll-indicator span:first-child{font-size:var(--text-2xl)}.features-section{padding:var(--space-24) var(--space-6);background:var(--color-cream)}.features-container{max-width:1200px;margin:0 auto}.section-title{font-family:var(--font-heading);font-size:clamp(2rem,6vw,3rem);font-weight:var(--font-bold);color:var(--color-charcoal);text-align:center;margin:0 0 var(--space-4) 0}.section-subtitle{font-size:var(--text-lg);color:var(--color-warm-gray);text-align:center;margin:0 0 var(--space-12) 0}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-6)}.feature-card{padding:var(--space-8) var(--space-6);background:#fff;border-radius:var(--radius-2xl);border:1px solid var(--color-warm-gray-lighter);transition:all var(--transition-base)}.feature-card:hover{box-shadow:var(--shadow-xl);border-color:transparent}.feature-icon{margin-bottom:var(--space-5)}.icon-circle{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--gradient-moroccan);border-radius:50%;font-size:1.8rem;box-shadow:var(--shadow-terracotta)}.feature-title{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-charcoal);margin:0 0 var(--space-3) 0}.feature-description{font-size:var(--text-base);color:var(--color-warm-gray);line-height:var(--leading-relaxed);margin:0}.pass-section{padding:var(--space-20) var(--space-6);background:linear-gradient(180deg,var(--color-cream) 0%,var(--color-sand) 100%)}.pass-card{max-width:900px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:var(--space-8);background:#fff;border-radius:var(--radius-3xl);padding:var(--space-8);box-shadow:var(--shadow-2xl);border:1px solid var(--color-warm-gray-lighter)}.pass-content{display:flex;flex-direction:column;gap:var(--space-4)}.pass-badge{display:inline-block;width:fit-content;padding:var(--space-1) var(--space-3);background:var(--color-emerald);color:#fff;font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full)}.pass-title{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-charcoal);margin:0}.pass-description{font-size:var(--text-lg);color:var(--color-warm-gray);margin:0}.pass-features{list-style:none;padding:0;margin:var(--space-4) 0;display:flex;flex-direction:column;gap:var(--space-3)}.pass-features li{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-base);color:var(--color-charcoal)}.pass-actions{display:flex;gap:var(--space-4);flex-wrap:wrap;margin-top:var(--space-4)}.pass-price-box{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);background:var(--gradient-moroccan);border-radius:var(--radius-2xl);color:#fff;text-align:center;min-width:180px}.price-badge{font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.05em;opacity:.9;margin-bottom:var(--space-2)}.price-amount{font-family:var(--font-heading);font-size:var(--text-5xl);font-weight:var(--font-bold);line-height:1}.price-period{font-size:var(--text-base);font-weight:var(--font-medium);margin-top:var(--space-2)}.price-note{font-size:var(--text-sm);opacity:.8;margin-top:var(--space-3);padding:var(--space-2) var(--space-4);background:#ffffff26;border-radius:var(--radius-full)}.how-section{padding:var(--space-24) var(--space-6);background:var(--color-cream)}.how-container{max-width:900px;margin:0 auto}.steps-container{display:flex;flex-direction:column;gap:var(--space-6);margin-top:var(--space-12)}.step-item{display:flex;align-items:flex-start;gap:var(--space-6);padding:var(--space-6);background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-md);border:1px solid var(--color-warm-gray-lighter)}.step-number{flex-shrink:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-bold);color:#fff;background:var(--gradient-moroccan);border-radius:50%;box-shadow:var(--shadow-terracotta)}.step-content{flex:1}.step-title{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-charcoal);margin:0 0 var(--space-2) 0}.step-description{font-size:var(--text-base);color:var(--color-warm-gray);line-height:var(--leading-relaxed);margin:0}.cta-section{position:relative;padding:var(--space-24) var(--space-6);overflow:hidden}.cta-background{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-moroccan)}.cta-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpolygon points='30,0 35,25 60,30 35,35 30,60 25,35 0,30 25,25' fill='white' opacity='0.05'/%3E%3C/svg%3E");background-size:60px 60px}.cta-content{position:relative;z-index:10;text-align:center;color:#fff;max-width:600px;margin:0 auto}.cta-title{font-family:var(--font-heading);font-size:clamp(2.5rem,8vw,4rem);font-weight:var(--font-bold);margin:0 0 var(--space-4) 0}.cta-subtitle{font-size:var(--text-xl);opacity:.9;margin:0 0 var(--space-8) 0}.landing-footer{padding:var(--space-10) var(--space-6);background:var(--color-charcoal);color:#fff}.footer-content{max-width:800px;margin:0 auto;text-align:center}.footer-brand{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-bold);margin-bottom:var(--space-4)}.footer-text{font-size:var(--text-base);margin:0 0 var(--space-2) 0;opacity:.9}.footer-tech{font-size:var(--text-sm);margin:0;opacity:.6}@media (max-width: 768px){.hero-section{padding:var(--space-16) var(--space-4) var(--space-8)}.hero-cta{flex-direction:column;width:100%;max-width:300px}.hero-stats{flex-direction:column;gap:var(--space-4)}.stat-divider{width:60px;height:1px}.hero-monuments{position:relative;bottom:0;flex-direction:column;align-items:center;margin-top:var(--space-8)}.monument-card{flex-direction:row;width:100%;max-width:280px;justify-content:center}.pass-card{grid-template-columns:1fr}.pass-price-box{order:-1;padding:var(--space-6)}.step-item{flex-direction:column;text-align:center;align-items:center}}@media (prefers-reduced-motion: reduce){.hero-monuments,.scroll-indicator{animation:none}}.toast-container{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:12px;pointer-events:none;max-width:90%;width:auto}.toast{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:var(--radius-full);background:#fff;box-shadow:var(--shadow-lg);font-size:.95rem;font-weight:500;pointer-events:auto;min-width:280px;max-width:500px;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.toast-visible{animation:slideDown .3s ease;opacity:1;transform:translateY(0)}.toast-hidden{animation:slideUp .3s ease;opacity:0;transform:translateY(-20px)}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.toast-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.toast-success{border-left:4px solid var(--color-emerald);background:#1d6b5c14}.toast-success .toast-icon{background:var(--color-emerald);color:#fff}.toast-error{border-left:4px solid var(--color-terracotta);background:#c75b3914}.toast-error .toast-icon{background:var(--color-terracotta);color:#fff}.toast-warning{border-left:4px solid var(--color-saffron);background:#e8a83814}.toast-warning .toast-icon{background:var(--color-saffron);color:#fff}.toast-info{border-left:4px solid var(--color-deep-blue);background:#1e4d6b14}.toast-info .toast-icon{background:var(--color-deep-blue);color:#fff}.toast-message{color:var(--color-charcoal);flex:1}@media (max-width: 767px){.toast-container{top:80px;max-width:95%}.toast{min-width:auto;width:100%;padding:12px 16px;font-size:.9rem}}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.map-view-container{position:relative;width:100%;height:500px;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-lg)}.leaflet-map{width:100%;height:100%;z-index:1}.marker-pin-photo{width:50px;height:50px;border-radius:50%;overflow:hidden;border:4px solid;box-shadow:0 4px 16px #2d29264d;background:#fff;display:flex;align-items:center;justify-content:center;animation:marker-float 3s ease-in-out infinite}.marker-pin-photo .marker-icon{font-size:1.5rem}.marker-pin-pointer{width:12px;height:12px;position:absolute;bottom:0;left:50%;transform:translate(-50%) rotate(45deg);margin-bottom:-6px;box-shadow:2px 2px 4px #2d292633}@keyframes marker-float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.marker-pin{width:40px;height:40px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2d292633;border:3px solid white}.marker-icon{transform:rotate(45deg);font-size:1.3rem}.user-marker-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;background:var(--color-deep-blue);border:3px solid white;border-radius:50%;box-shadow:0 2px 8px #1e4d6b66;z-index:2}.user-marker-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;background:#1e4d6b4d;border-radius:50%;animation:pulse-ring 2s ease-out infinite}.leaflet-popup-content-wrapper{border-radius:var(--radius-2xl);padding:0;background:#fff;box-shadow:var(--shadow-xl);border:1px solid rgba(199,91,57,.15)}.leaflet-popup-content{margin:0;width:auto!important}.leaflet-popup-tip{background:#fff;border:1px solid rgba(199,91,57,.15);border-top:none;border-right:none}.popup-content{padding:20px}.popup-title{font-family:var(--font-heading);font-size:1.3rem;font-weight:600;color:var(--color-charcoal);margin:0 0 4px}.popup-subtitle{font-size:.95rem;color:var(--color-warm-gray);margin:0 0 12px;font-style:italic}.nearest-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--gradient-moroccan);color:#fff;border-radius:var(--radius-full);font-size:.85rem;font-weight:600;margin-bottom:12px}.popup-image{width:100%;height:150px;object-fit:cover;border-radius:var(--radius-xl);margin:12px 0}.popup-description{font-size:.9rem;line-height:1.6;color:var(--color-warm-gray);margin:12px 0}.popup-distance{display:flex;align-items:center;gap:8px;padding:10px;background:var(--color-sand-light);border-radius:var(--radius-lg);margin:12px 0;font-size:.9rem;color:var(--color-charcoal);font-weight:500}.distance-icon{font-size:1.2rem}.view-details-popup-btn{width:100%;padding:12px;background:var(--gradient-moroccan);color:#fff;border:none;border-radius:var(--radius-lg);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);margin-top:8px;box-shadow:var(--shadow-terracotta)}.view-details-popup-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #c75b3959}.user-popup h4{font-family:var(--font-heading);font-size:1.1rem;color:var(--color-charcoal);margin:0 0 8px}.user-popup p{font-size:.9rem;color:var(--color-warm-gray);margin:0}.map-legend{position:absolute;bottom:20px;left:20px;background:#fdf8f3f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:16px;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);z-index:1000;border:1px solid rgba(199,91,57,.15)}.legend-title{font-family:var(--font-heading);font-size:.9rem;font-weight:600;color:var(--color-charcoal);margin:0 0 12px}.legend-items{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--color-warm-gray)}.legend-marker{width:16px;height:16px;border-radius:50%;flex-shrink:0}.legend-marker.user-marker{background:var(--color-deep-blue);border:2px solid white;box-shadow:0 2px 4px #1e4d6b4d}.legend-marker.monument-marker{background:var(--color-terracotta);border:2px solid white;box-shadow:0 2px 4px #c75b394d}.legend-circle{width:16px;height:16px;border:2px dashed var(--color-terracotta);border-radius:50%;flex-shrink:0}.leaflet-control-zoom{border:1px solid rgba(199,91,57,.15)!important;border-radius:var(--radius-xl)!important;overflow:hidden;box-shadow:var(--shadow-md)!important}.leaflet-control-zoom a{width:36px!important;height:36px!important;line-height:36px!important;font-size:20px!important;color:var(--color-charcoal)!important;background:#fff!important;border:none!important}.leaflet-control-zoom a:hover{background:var(--color-sand-light)!important;color:var(--color-terracotta)!important}.leaflet-control-attribution{background:#fdf8f3e6!important;border-radius:var(--radius-md)!important;padding:4px 8px!important;font-size:.75rem!important;margin:10px!important}@media (max-width: 768px){.map-view-container{height:400px;border-radius:var(--radius-xl)}.map-legend{bottom:10px;left:10px;padding:12px;font-size:.8rem}.legend-title{font-size:.85rem}.popup-content{padding:16px}.popup-title{font-size:1.1rem}.popup-image{height:120px}}:root{--primary-gradient: linear-gradient(135deg, #C75B39 0%, #E8A838 100%);--primary-color: #C75B39;--secondary-color: #1E4D6B;--accent-color: #E8A838;--success-color: #1D6B5C;--warning-color: #E8A838;--error-color: #C75B39;--background-warm: #FDF8F3;--glass-bg: rgba(253, 248, 243, .95);--glass-border: rgba(199, 91, 57, .2);--text-dark: #2D2926;--text-light: #6B5E54;--shadow-sm: 0 2px 8px rgba(45, 41, 38, .06);--shadow-md: 0 4px 16px rgba(45, 41, 38, .08);--shadow-lg: 0 8px 32px rgba(45, 41, 38, .1);--shadow-xl: 0 20px 60px rgba(45, 41, 38, .12)}*{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}h1,h2,h3,h4,h5,h6{font-family:Poppins,sans-serif}.app{min-height:100vh;padding:0;max-width:100%;margin:0;position:relative;overflow-x:hidden;background:var(--background-warm)}.header{position:sticky;top:0;z-index:100;padding:20px;text-align:center;color:#fff;background:var(--primary-gradient);box-shadow:var(--shadow-md)}.header h1{font-size:clamp(1.5rem,5vw,2.2rem);margin-bottom:8px;font-weight:700;letter-spacing:-.5px}.header p{font-size:clamp(.9rem,3vw,1.1rem);opacity:.95;font-weight:400;margin-bottom:16px}.location-status{display:flex;justify-content:center;margin-top:16px;padding:0 12px}.access-pass{margin-top:14px;display:flex;justify-content:center;padding:0 12px}.pass-valid{width:100%;max-width:720px;display:flex;justify-content:space-between;align-items:center;background:#a7d7c533;border:1px solid rgba(167,215,197,.4);border-radius:14px;padding:12px 16px;gap:12px}.pass-title{margin:0;font-weight:700;color:#0f172a}.pass-meta{margin:2px 0 0;color:#334155;font-size:.95rem}.pill-btn{padding:10px 14px;border-radius:999px;border:1px solid #e5e7eb;background:#f8fafc;color:#0f172a;font-weight:700;cursor:pointer}.pill-btn.primary{background:var(--primary-gradient);color:#fff;border:none;box-shadow:0 4px 15px #c75b394d}.pill-btn.ghost{background:#fff}.pass-form{width:100%;max-width:900px;background:#ffffffd9;border:1px solid rgba(196,181,253,.35);border-radius:16px;padding:12px 14px;box-shadow:var(--shadow-sm)}.pass-input-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.pass-input-row input{flex:1;min-width:200px;padding:10px 12px;border-radius:10px;border:1px solid #e2e8f0;font-size:1rem;outline:none}.pass-input-row input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #c75b3926}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:50px;font-size:.9rem;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);animation:fadeIn .4s ease}.status-badge.loading{background:#a7e6e64d;border-color:#a7e6e680;color:#4a4a4a}.status-badge.success{background:#a7d7c54d;border-color:#a7d7c580;color:#4a4a4a}.status-badge.warning{background:#ffd8a84d;border-color:#ffd8a880;color:#4a4a4a}.status-badge.error{background:#ffb3ba4d;border-color:#ffb3ba80;color:#4a4a4a}.spinner{width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.main-container{display:flex;flex-direction:column;height:calc(100vh - 160px);position:relative;background:#000}.video-container{flex:1;position:relative;width:100%;background:#000;overflow:hidden;max-height:50vh}.video-feed{width:100%;height:100%;object-fit:cover}.video-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e5d4ff,#ffe5e5,#d4f4f4);color:var(--text-dark)}.placeholder-content{text-align:center;padding:20px}.camera-icon{font-size:4rem;display:block;margin-bottom:16px;opacity:.8;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.placeholder-content p{font-size:1.2rem;margin-bottom:8px;font-weight:500}.placeholder-content small{font-size:.9rem;opacity:.8}.conversation-panel{flex:1;background:#fff;display:flex;flex-direction:column;max-height:50vh;border-top:1px solid #e5e7eb}.messages-container{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px}.btn{padding:16px 32px;border:none;border-radius:50px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.95)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--primary-gradient);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 8px 24px #c75b3966;transform:translateY(-2px)}.btn-danger{background:var(--error-color);color:#fff}.btn-danger:hover{background:#ff9aa0;box-shadow:0 8px 24px #ffb3ba66;transform:translateY(-2px)}.btn-large{padding:18px 40px;font-size:1.1rem}.floating-controls{position:absolute;bottom:80px;left:50%;transform:translate(-50%);z-index:20}.map-button{position:fixed;bottom:20px;left:20px;width:70px;height:70px;border-radius:50%;background:var(--primary-gradient);color:#fff;border:none;box-shadow:var(--shadow-lg);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:.75rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1000;animation:pulse-subtle 3s ease-in-out infinite}@keyframes pulse-subtle{0%,to{box-shadow:0 8px 32px #c4b5fd66}50%{box-shadow:0 8px 32px #c4b5fd99}}.map-button:hover{transform:scale(1.1);box-shadow:0 12px 40px #c4b5fd99;animation:none}.map-button:active{transform:scale(.95)}.map-icon{font-size:1.8rem}.live-indicator{position:absolute;top:20px;left:20px;background:#ffb3baf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:8px 16px;border-radius:20px;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:8px;z-index:10;animation:fadeIn .3s ease;box-shadow:var(--shadow-md)}.status{position:absolute;top:20px;right:20px;display:flex;align-items:center;gap:8px;padding:10px 16px;background:#10b981f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-weight:600;font-size:.9rem;border-radius:50px;box-shadow:var(--shadow-md);z-index:10}.status-dot{width:10px;height:10px;background:#fff;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.image-flashcard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease;cursor:pointer}.image-flashcard{background:#fff;border-radius:24px;max-width:500px;width:100%;overflow:hidden;box-shadow:var(--shadow-xl);animation:slideUp .4s cubic-bezier(.4,0,.2,1);cursor:default;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.image-flashcard img{width:100%;height:300px;object-fit:cover;display:block}.image-flashcard-content{padding:24px}.image-flashcard-content h3{font-size:1.5rem;color:var(--text-dark);margin-bottom:12px;font-weight:700}.image-flashcard-content p{font-size:1rem;color:var(--text-light);line-height:1.6}.close-btn{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:none;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.close-btn:hover{background:#000c;transform:rotate(90deg)}.card-progress{position:absolute;top:20px;left:20px;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:8px 16px;border-radius:20px;font-size:.85rem;font-weight:600;z-index:10;animation:fadeIn .3s ease}.card-navigation{display:flex;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background:#f9fafb}.nav-btn{flex:1;padding:12px 24px;border:none;border-radius:12px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.nav-btn.prev-btn{background:#e5e7eb;color:var(--text-dark)}.nav-btn.prev-btn:hover:not(:disabled){background:#d1d5db;transform:translate(-2px)}.nav-btn.prev-btn:disabled{opacity:.5;cursor:not-allowed}.nav-btn.next-btn{background:var(--primary-gradient);color:#fff}.nav-btn.next-btn:hover{transform:translate(2px);box-shadow:var(--shadow-md)}.dismiss-all-btn{width:calc(100% - 48px);margin:0 24px 16px;padding:10px 20px;background:#f3f4f6;color:var(--text-light);border:1px solid #d1d5db;border-radius:10px;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s}.dismiss-all-btn:hover{background:#e5e7eb;color:var(--text-dark);border-color:#9ca3af}.map-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}.map-modal{background:#fff;border-radius:24px;width:100%;max-width:600px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .4s cubic-bezier(.4,0,.2,1);position:relative}.map-modal h2{padding:24px 24px 16px;margin:0;color:var(--text-dark);font-size:1.5rem;font-weight:700;border-bottom:1px solid #e5e7eb}.map-modal-header{display:flex;align-items:center;justify-content:space-between;padding-right:60px}.map-modal-header h2{border-bottom:none;padding-bottom:0}.expand-map-btn{padding:8px 16px;background:var(--primary-gradient);color:#fff;border:none;border-radius:20px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.expand-map-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #c75b3966}.map-content{padding:20px}.location-info{margin-bottom:24px}.info-card{background:var(--primary-gradient);color:#fff;padding:20px;border-radius:16px;box-shadow:var(--shadow-md)}.info-card h3{margin:0 0 12px;font-size:1.2rem;font-weight:600}.info-card p{margin:4px 0;font-size:.95rem;opacity:.95}.monuments-list{margin-top:24px}.monuments-list h3{margin:0 0 16px;color:var(--text-dark);font-size:1.2rem;font-weight:700}.monument-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s}.monument-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.monument-card.nearby{background:#a7d7c526;border-color:#a7d7c5}.monument-card.active{background:#c75b391a;border-color:var(--primary-color)}.monument-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.monument-header h4{margin:0;color:var(--text-dark);font-size:1.1rem;font-weight:600}.distance-badge{background:#f3f4f6;color:var(--text-dark);padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600}.monument-location{color:var(--text-light);font-size:.9rem;margin:4px 0 8px}.nearby-badge{display:inline-block;background:var(--success-color);color:#fff;padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600;margin-top:8px}.view-details-btn{width:100%;margin-top:12px;padding:10px;background:#f9fafb;color:var(--text-dark);border:1px solid #e5e7eb;border-radius:10px;font-weight:500;cursor:pointer;transition:all .2s}.view-details-btn:hover{background:var(--background-warm);border-color:var(--primary-color);color:var(--primary-color)}.monument-details-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}.monument-details-modal{background:#fff;border-radius:24px;width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .4s cubic-bezier(.4,0,.2,1);position:relative}.monument-details-modal h2{padding:24px 24px 16px;margin:0;color:var(--text-dark);font-size:1.8rem;font-weight:700;border-bottom:2px solid #e5e7eb}.details-content{padding:24px}.detail-section{margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.detail-section:last-of-type{border-bottom:none}.detail-section h3{margin:0 0 16px;color:var(--text-dark);font-size:1.3rem;font-weight:700}.detail-section p{margin:8px 0;color:var(--text-dark);line-height:1.6}.detail-section strong{color:var(--primary-color);font-weight:600}.fact-item{background:#f9fafb;padding:16px;border-radius:12px;margin-bottom:16px;border:1px solid #e5e7eb}.fact-item:last-child{margin-bottom:0}.fact-image{width:100%;height:200px;object-fit:cover;border-radius:8px;margin-bottom:12px}.fact-item h4{margin:0 0 8px;color:var(--text-dark);font-size:1.1rem;font-weight:600}.fact-item p{margin:0;color:var(--text-light);line-height:1.5}.info-section{display:flex;flex-direction:column;gap:0;background:#f9fafb}.chat-container,.flashcards-container{background:#fff;padding:24px;border-top:1px solid #e5e7eb}.chat-container h2,.flashcards-container h2{margin-bottom:20px;color:var(--text-dark);font-size:1.3rem;font-weight:700;display:flex;align-items:center;gap:8px}.messages{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding:4px}.message{padding:14px 18px;border-radius:18px;max-width:85%;animation:slideIn .3s ease;line-height:1.5;box-shadow:var(--shadow-sm)}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{background:linear-gradient(135deg,#c75b39,#e07b5c);color:#fff;align-self:flex-end;margin-left:auto;border-bottom-right-radius:4px;box-shadow:0 4px 15px #c75b3940}.message.model{background:linear-gradient(135deg,#ffe5e5,#fff5e5);color:var(--text-dark);align-self:flex-start;border-bottom-left-radius:4px;border:1px solid rgba(255,201,201,.3)}.message.error{background:#ffb3ba33;color:#d64b52;align-self:center;text-align:center;border:1px solid rgba(255,179,186,.4)}.message.thinking{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);padding:16px 20px;min-width:70px}.thinking-dots{display:flex;gap:6px;align-items:center;justify-content:center}.thinking-dots span{width:8px;height:8px;background:#9ca3af;border-radius:50%;animation:thinkingBounce 1.4s infinite ease-in-out both}.thinking-dots span:nth-child(1){animation-delay:-.32s}.thinking-dots span:nth-child(2){animation-delay:-.16s}.thinking-dots span:nth-child(3){animation-delay:0s}@keyframes thinkingBounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.cta-btn.connecting{opacity:.8;pointer-events:none}.cta-btn .spinner-icon{animation:spin 1s linear infinite}.message-content{white-space:pre-wrap;word-wrap:break-word}.empty-state{text-align:center;color:var(--text-light);padding:60px 20px;font-size:1rem}.flashcards-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-count-badge{background:var(--primary-gradient);color:#fff;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:600;box-shadow:var(--shadow-sm)}.card-controls{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.card-search{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:.95rem;transition:all .2s;outline:none}.card-search:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #c75b391a}.card-filters{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{padding:8px 16px;border:2px solid #e5e7eb;background:#fff;border-radius:10px;font-size:.9rem;font-weight:500;color:var(--text-dark);cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:var(--primary-color);background:var(--background-warm)}.filter-btn.active{background:var(--primary-gradient);color:#fff;border-color:transparent;box-shadow:var(--shadow-sm)}.flashcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.flashcard-wrapper{display:flex;flex-direction:column;gap:10px}.card-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 4px}.learn-btn{flex:1;padding:8px 12px;border:2px solid #e5e7eb;background:#fff;border-radius:8px;font-size:.85rem;font-weight:500;color:var(--text-dark);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:4px}.learn-btn:hover{border-color:#10b981;background:#f0fdf4}.learn-btn.learned{background:#10b981;color:#fff;border-color:#10b981}.learn-btn.learned:hover{background:#059669}.card-type-badge{padding:6px 10px;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap}.card-type-badge.ai{background:#dbeafe;color:#1e40af}.card-type-badge.predefined{background:#fef3c7;color:#92400e}.no-cards-message{text-align:center;padding:40px 20px;color:var(--text-light);font-size:.95rem}.messages::-webkit-scrollbar{width:8px}.messages::-webkit-scrollbar-track{background:transparent}.messages::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:10px}.messages::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (min-width: 768px){.app{padding:0}.header{padding:30px 40px}.main-content{flex-direction:row;min-height:calc(100vh - 180px)}.video-section{flex:1;max-width:50%;position:sticky;top:180px;height:fit-content}.video-container{height:500px}.info-section{flex:1;max-width:50%}.controls{position:static;transform:none;margin-top:20px;bottom:auto}.status{top:20px;right:20px}.flashcards{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}}@media (min-width: 1024px){.video-container{height:600px}.messages{max-height:500px}}@media (max-width: 767px){.btn{padding:14px 28px;font-size:1rem}.video-container{height:50vh;min-height:350px}.controls{bottom:16px}.status{top:16px;right:16px;font-size:.85rem;padding:8px 12px}.image-flashcard{max-width:100%;margin:0 16px}.image-flashcard img{height:250px}.image-flashcard-content{padding:20px}.image-flashcard-content h3{font-size:1.3rem}.message{max-width:90%}.flashcards{grid-template-columns:1fr}}@supports (padding: env(safe-area-inset-bottom)){.info-section{padding-bottom:env(safe-area-inset-bottom)}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:70px;background:#fff;border-top:1px solid #e5e7eb;display:flex;justify-content:space-around;align-items:center;z-index:100;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -4px 20px #00000014}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;color:var(--text-light);font-size:.7rem;font-weight:500;cursor:pointer;padding:8px 16px;border-radius:12px;transition:all .2s ease}.nav-item:hover{background:#c4b5fd1a}.nav-item.active{color:var(--primary-color)}.nav-item.active .nav-icon{transform:scale(1.1)}.nav-item:disabled{opacity:.4;cursor:not-allowed}.nav-icon{font-size:1.4rem;transition:transform .2s ease}.nav-label{font-weight:600}.main-container{padding-bottom:90px}.dual-cta-container{position:fixed;bottom:90px;left:50%;transform:translate(-50%);display:flex;gap:12px;z-index:50;padding:0 20px;width:100%;max-width:400px;justify-content:center}.cta-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border:none;border-radius:50px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg);white-space:nowrap}.cta-btn:disabled{opacity:.5;cursor:not-allowed}.cta-btn .cta-icon{font-size:1.2rem}.cta-ar-main{background:var(--primary-gradient);color:#fff;width:100%;box-shadow:0 6px 20px #c75b394d}.cta-ar-main:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #c75b3966}.cta-end{background:var(--error-color);color:#fff;width:100%}.cta-end:hover{background:#ff9aa0;transform:translateY(-2px)}.ar-frame-guide{position:absolute;top:30px;right:30px;bottom:30px;left:30px;pointer-events:none;z-index:5}.corner{position:absolute;width:50px;height:50px;border:4px solid rgba(255,255,255,.9);border-radius:8px}.corner.top-left{top:0;left:0;border-right:none;border-bottom:none;border-top-left-radius:16px}.corner.top-right{top:0;right:0;border-left:none;border-bottom:none;border-top-right-radius:16px}.corner.bottom-left{bottom:0;left:0;border-right:none;border-top:none;border-bottom-left-radius:16px}.corner.bottom-right{bottom:0;right:0;border-left:none;border-top:none;border-bottom-right-radius:16px}.frame-hint{position:absolute;bottom:80px;left:50%;transform:translate(-50%);background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:10px 20px;border-radius:25px;font-size:.9rem;font-weight:500;white-space:nowrap;animation:fadeInUp .5s ease}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.monument-details-modal{background:#fff;border-radius:24px;width:100%;max-width:500px;max-height:75vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);animation:slideUp .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.modal-sticky-header{position:sticky;top:0;background:#fff;z-index:10;padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:flex-start}.modal-header-content h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-dark)}.modal-subtitle{margin:4px 0 0;font-size:1rem;color:var(--text-light);font-family:Noto Sans Arabic,sans-serif}.modal-close-btn{width:40px;height:40px;border-radius:50%;background:#f3f4f6;color:var(--text-dark);border:none;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.modal-close-btn:hover{background:#e5e7eb;transform:rotate(90deg)}.modal-tabs{display:flex;gap:4px;padding:12px 16px;background:#f9fafb;border-bottom:1px solid #e5e7eb;overflow-x:auto;-webkit-overflow-scrolling:touch}.modal-tabs::-webkit-scrollbar{display:none}.tab-btn{padding:10px 16px;border:none;background:transparent;color:var(--text-light);font-size:.9rem;font-weight:600;cursor:pointer;border-radius:10px;transition:all .2s;white-space:nowrap}.tab-btn:hover{background:#c4b5fd26;color:var(--text-dark)}.tab-btn.active{background:var(--primary-gradient);color:#fff;box-shadow:var(--shadow-sm)}.modal-tab-content{flex:1;overflow-y:auto;padding:0}.tab-panel{padding:20px;animation:fadeIn .3s ease}.about-hero{margin:-20px -20px 20px}.about-hero-image{width:100%;height:200px;object-fit:cover}.about-description{font-size:1rem;line-height:1.7;color:var(--text-dark);margin-bottom:20px}.location-info-card{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#c4b5fd26,#a7e6e626);padding:16px;border-radius:12px;border:1px solid rgba(196,181,253,.3)}.location-icon{font-size:1.5rem}.location-info-card strong{display:block;color:var(--text-dark);font-size:1rem}.location-info-card small{color:var(--text-light);font-size:.85rem}.photos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.photo-item{aspect-ratio:1;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.photo-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.photo-item:hover img{transform:scale(1.05)}.facilities-list{display:flex;flex-direction:column;gap:12px}.facility-item{display:flex;align-items:center;gap:12px;padding:16px;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb}.facility-icon{font-size:1.5rem}.facility-item span:last-child{color:var(--text-dark);font-weight:500}.prices-container{display:flex;flex-direction:column;gap:24px}.price-section h4{margin:0 0 12px;font-size:1.1rem;color:var(--text-dark)}.price-list{display:flex;flex-direction:column;gap:8px}.price-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f9fafb;border-radius:10px;border:1px solid #e5e7eb}.price-category{color:var(--text-dark);font-weight:500}.price-amount{color:var(--primary-color);font-weight:700;font-size:1.1rem}.tips-list{display:flex;flex-direction:column;gap:12px}.tip-item{display:flex;align-items:flex-start;gap:12px;padding:16px;background:linear-gradient(135deg,#ffd8a833,#fff5e54d);border-radius:12px;border:1px solid rgba(255,216,168,.4)}.tip-icon{font-size:1.3rem;flex-shrink:0}.tip-item p{margin:0;color:var(--text-dark);line-height:1.5}.no-data{text-align:center;padding:40px 20px;color:var(--text-light)}.modal-sticky-footer{position:sticky;bottom:0;background:#fff;padding:16px 20px;border-top:1px solid #e5e7eb;display:flex;gap:12px;box-shadow:0 -4px 20px #00000014}.modal-sticky-footer .cta-btn{width:100%;padding:14px 20px}.cta-ar{background:var(--primary-gradient);color:#fff;box-shadow:0 6px 20px #c75b394d}.map-button,.floating-controls{display:none}@media (max-width: 767px){.monument-details-modal{max-width:100%;max-height:80vh;margin:0 10px;border-radius:20px 20px 0 0}.modal-sticky-header{padding:16px 20px}.modal-header-content h2{font-size:1.3rem}.tab-btn{padding:8px 12px;font-size:.85rem}.dual-cta-container{bottom:85px;padding:0 16px}.cta-btn{padding:12px 16px;font-size:.85rem}}.header{background:var(--gradient-moroccan, var(--primary-gradient));position:relative;overflow:hidden}.header:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpolygon points='30,0 35,25 60,30 35,35 30,60 25,35 0,30 25,25' fill='white' opacity='0.05'/%3E%3C/svg%3E");background-size:60px 60px;pointer-events:none}.header h1{font-family:Playfair Display,serif;letter-spacing:-.02em}.message{border-radius:20px 20px 20px 4px;position:relative}.message.user{background:linear-gradient(135deg,#c75b39,#e07b5c);color:#fff;border-radius:20px 20px 4px;box-shadow:0 4px 15px #c75b3940}.message.ai{background:#fff;border:1px solid rgba(199,91,57,.15);box-shadow:0 4px 15px #00000014}.ar-frame-guide{border:3px solid var(--color-terracotta, #C75B39);border-radius:20px;box-shadow:0 0 0 6px #c75b3933}.status-badge{border-radius:var(--radius-full, 50px);font-family:var(--font-body, "Inter", sans-serif)}.status-badge.success{background:#1d6b5c26;border-color:#1d6b5c4d;color:#1d6b5c}.status-badge.loading,.status-badge.warning{background:#e8a83826;border-color:#e8a8384d;color:#c98e2a}.status-badge.error{background:#c75b3926;border-color:#c75b394d;color:#c75b39}.bottom-nav{background:linear-gradient(180deg,#fdf8f3f2,#fdf8f3);border-top:1px solid rgba(199,91,57,.15);box-shadow:0 -4px 20px #00000014}.nav-btn.active{color:#c75b39}.nav-btn.active:after{background:linear-gradient(135deg,#c75b39,#e8a838);box-shadow:0 2px 8px #c75b3966}.connect-btn{background:linear-gradient(135deg,#c75b39,#e8a838);box-shadow:0 8px 30px #c75b3959}.connect-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px #c75b3973}.connect-btn.connected{background:linear-gradient(135deg,#c75b39,#a44a2d)}.live-indicator{background:linear-gradient(135deg,#1d6b5c,#278f7a);box-shadow:0 0 20px #1d6b5c80}.live-dot{background:#fdf8f3;box-shadow:0 0 10px #fdf8f3cc}.ai-thinking{background:#e8a8381a;border:1px solid rgba(232,168,56,.3)}.ai-thinking:before{background:linear-gradient(90deg,transparent,rgba(232,168,56,.3),transparent)}.thinking-dots span{background:#e8a838}.tab-btn{font-weight:var(--font-medium, 500);transition:all .2s ease}.tab-btn.active{background:linear-gradient(135deg,#c75b39,#e8a838);color:#fff;box-shadow:0 4px 15px #c75b394d}.monument-details-modal{border-radius:var(--radius-3xl, 32px);border:1px solid rgba(199,91,57,.1)}.modal-sticky-header{background:linear-gradient(180deg,#fff,#fdf8f3f2);border-bottom:1px solid rgba(199,91,57,.1)}.cta-btn.primary{background:linear-gradient(135deg,#c75b39,#e8a838);color:#fff;box-shadow:0 8px 30px #c75b394d}.cta-btn.secondary{background:#fff;border:2px solid #C75B39;color:#c75b39}.pill-btn.primary{background:linear-gradient(135deg,#c75b39,#e8a838);box-shadow:0 4px 15px #c75b394d}.image-flashcard{border-radius:var(--radius-3xl, 32px);border:1px solid rgba(199,91,57,.15)}.flashcard-header{background:linear-gradient(135deg,#c75b39,#e8a838)}.pass-valid{background:#1d6b5c1a;border:1px solid rgba(29,107,92,.2)}.pass-form{background:#fff;border:1px solid rgba(199,91,57,.2)}.pass-input-row input:focus{border-color:#c75b39;box-shadow:0 0 0 3px #c75b3926}.map-modal-overlay{background:#2d2926b3}.map-modal-content{border-radius:var(--radius-3xl, 32px)}button:focus-visible,input:focus-visible{outline:2px solid #D4A853;outline-offset:2px}.connect-btn,.nav-btn,.tab-btn,.pill-btn,.cta-btn{transition:all .2s cubic-bezier(.4,0,.2,1)}[data-tutorial]{position:relative}.purchase-page{min-height:100vh;padding:48px 24px 80px;background:linear-gradient(180deg,var(--color-cream) 0%,var(--color-sand) 100%);font-family:var(--font-body)}.purchase-hero{max-width:960px;margin:0 auto 32px;text-align:left}.back-btn{background:none;border:none;color:var(--color-terracotta);font-weight:600;cursor:pointer;margin-bottom:12px;font-size:1rem;transition:color var(--transition-fast)}.back-btn:hover{color:var(--color-terracotta-dark)}.eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;color:var(--color-warm-gray);margin:0 0 8px}.purchase-hero h1{font-family:var(--font-heading);font-size:clamp(2.3rem,4vw,3rem);margin:0 0 12px;color:var(--color-charcoal)}.subtitle{color:var(--color-warm-gray);max-width:640px;line-height:1.6;margin:0}.active-pass{max-width:960px;margin:0 auto 20px;padding:16px 20px;background:#1d6b5c1a;border:1px solid rgba(29,107,92,.3);border-radius:var(--radius-xl);display:flex;justify-content:space-between;align-items:center;gap:16px}.active-pass .label{margin:0;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:var(--color-emerald)}.active-pass .code{margin:4px 0;font-weight:700;color:var(--color-emerald-dark);word-break:break-all}.active-pass .meta{margin:0;color:var(--color-charcoal);font-size:.95rem}.purchase-grid{max-width:960px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.plan-card{background:#fff;padding:24px;border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);position:relative;border:1px solid var(--color-warm-gray-lighter)}.badge{position:absolute;top:16px;right:16px;background:var(--gradient-moroccan);color:#fff;padding:6px 12px;border-radius:var(--radius-full);font-size:.85rem;font-weight:700}.plan-card h2{font-family:var(--font-heading);margin:4px 0 8px;color:var(--color-charcoal)}.plan-copy{color:var(--color-warm-gray);line-height:1.6;margin:0 0 16px}.price-row{display:flex;align-items:baseline;gap:6px;margin-bottom:16px}.price{font-family:var(--font-heading);font-size:2.4rem;font-weight:800;color:var(--color-charcoal)}.price-hint{color:var(--color-warm-gray);font-weight:600}.benefits{list-style:none;padding:0;margin:0 0 16px;display:grid;gap:10px}.benefits li{display:flex;align-items:center;gap:10px;color:var(--color-charcoal)}.benefits li:before{content:"✓";color:var(--color-emerald);font-weight:700}.primary-btn{width:100%;padding:14px 16px;background:var(--gradient-moroccan);color:#fff;font-weight:700;border:none;border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-terracotta)}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.primary-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #c75b3959}.secondary-btn{padding:12px 14px;background:var(--color-sand-light);border:1px solid var(--color-warm-gray-lighter);border-radius:var(--radius-lg);font-weight:700;color:var(--color-charcoal);cursor:pointer;transition:all var(--transition-fast)}.error{margin:10px 0 0;color:var(--color-terracotta);font-weight:600}.info-card{background:#fff;padding:24px;border-radius:var(--radius-2xl);box-shadow:var(--shadow-md);border:1px solid var(--color-warm-gray-lighter)}.info-card h3{font-family:var(--font-heading);margin-top:0;color:var(--color-charcoal)}.info-card ol{padding-left:18px;color:var(--color-warm-gray);line-height:1.6}.hint{color:var(--color-warm-gray);background:var(--color-sand-light);padding:12px;border-radius:var(--radius-lg);border:1px solid var(--color-warm-gray-lighter)}@media (max-width: 640px){.purchase-page{padding:32px 16px 60px}.active-pass{flex-direction:column;align-items:flex-start}.plan-card,.info-card{padding:20px}}.success-page{min-height:100vh;background:linear-gradient(180deg,var(--color-sand-light) 0%,var(--color-cream) 100%);display:flex;align-items:center;justify-content:center;padding:40px 20px;font-family:var(--font-body)}.card{background:#fff;padding:28px;max-width:720px;width:100%;border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);border:1px solid var(--color-warm-gray-lighter)}.card h1{font-family:var(--font-heading);margin:6px 0 12px;color:var(--color-charcoal);font-size:clamp(2rem,5vw,2.6rem)}.subtitle{color:var(--color-warm-gray);line-height:1.6;margin:0 0 18px}.eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;color:var(--color-emerald);margin:0;font-weight:var(--font-semibold)}.code-box{display:flex;gap:12px;align-items:center;background:var(--color-charcoal);color:var(--color-sand);padding:14px 16px;border-radius:var(--radius-xl);font-family:Space Mono,monospace;overflow:auto}.code-text{flex:1;word-break:break-all}.secondary-btn,.ghost-btn{padding:12px 14px;border-radius:var(--radius-lg);font-weight:700;cursor:pointer;border:1px solid var(--color-warm-gray-lighter);transition:all var(--transition-fast)}.secondary-btn{background:var(--color-sand-light);color:var(--color-charcoal)}.secondary-btn:hover{background:var(--color-sand)}.ghost-btn{background:#fff;color:var(--color-charcoal)}.ghost-btn:hover{background:var(--color-sand-light)}.primary-btn{padding:14px 16px;background:var(--gradient-moroccan);color:#fff;font-weight:700;border:none;border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-terracotta)}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px #c75b3959}.meta{color:var(--color-charcoal);margin:10px 0 0}.actions{display:flex;gap:12px;margin-top:16px}.hint{background:var(--color-sand-light);padding:12px;border-radius:var(--radius-lg);border:1px solid var(--color-warm-gray-lighter);color:var(--color-warm-gray)}.error{color:var(--color-terracotta);font-weight:600}@media (max-width: 640px){.card{padding:22px}.actions{flex-direction:column}}.map-page{min-height:100vh;display:flex;flex-direction:column;background:#f9fafb}.map-header{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e5e7eb}.map-header h1{font-size:1.2rem;font-weight:700;color:#1f2937;margin:0}.map-header .back-btn{background:none;border:none;font-size:1rem;color:#6366f1;cursor:pointer;padding:8px 0;font-weight:600}.list-toggle-btn{width:40px;height:40px;border-radius:12px;background:#f3f4f6;border:none;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.list-toggle-btn:hover{background:#e5e7eb}.map-container-full{flex:1;position:relative;margin-top:65px;margin-bottom:70px}.leaflet-map-full{width:100%;height:calc(100vh - 135px);z-index:1}.map-location-status{position:absolute;top:16px;left:16px;z-index:500}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:50px;font-size:.85rem;font-weight:500;background:#fff;box-shadow:0 2px 12px #0000001a}.status-pill.loading{background:#eef2ff;color:#4338ca}.status-pill.success{background:#ecfdf5;color:#059669}.status-pill.error{background:#fef2f2;color:#dc2626}.status-pill .spinner{width:14px;height:14px;border:2px solid rgba(67,56,202,.3);border-top-color:#4338ca;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.monument-drawer{position:fixed;top:65px;right:-100%;width:100%;max-width:400px;height:calc(100vh - 135px);background:#fff;z-index:600;transition:right .3s ease;box-shadow:-4px 0 20px #0000001a;display:flex;flex-direction:column}.monument-drawer.open{right:0}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e5e7eb}.drawer-header h2{font-size:1.2rem;font-weight:700;margin:0;color:#1f2937}.close-drawer{width:36px;height:36px;border-radius:50%;background:#f3f4f6;border:none;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.drawer-content{flex:1;overflow-y:auto;padding:12px}.monument-list-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;cursor:pointer;transition:all .2s;margin-bottom:8px}.monument-list-item:hover{background:#f9fafb}.monument-list-item.selected{background:linear-gradient(135deg,#c4b5fd33,#a7e6e633);border:1px solid rgba(196,181,253,.4)}.monument-thumb{width:56px;height:56px;border-radius:12px;overflow:hidden;flex-shrink:0;background:#f3f4f6;display:flex;align-items:center;justify-content:center}.monument-thumb img{width:100%;height:100%;object-fit:cover}.monument-emoji{font-size:1.5rem}.monument-info{flex:1;min-width:0}.monument-info h3{font-size:.95rem;font-weight:600;color:#1f2937;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monument-info p{font-size:.85rem;color:#6b7280;margin:0}.monument-distance{flex-shrink:0}.monument-distance span{display:inline-block;padding:6px 12px;background:#f3f4f6;border-radius:20px;font-size:.8rem;font-weight:600;color:#6b7280}.monument-distance span.nearby{background:linear-gradient(135deg,#c4b5fd,#a7e6e6);color:#fff}.monument-detail-sheet{position:fixed;bottom:70px;left:0;right:0;background:#fff;border-radius:24px 24px 0 0;box-shadow:0 -4px 30px #00000026;z-index:700;max-height:60vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.close-sheet{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:#00000080;color:#fff;border:none;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10}.sheet-header{position:relative;height:180px}.sheet-hero-image{width:100%;height:100%;object-fit:cover}.sheet-title-overlay{position:absolute;bottom:0;left:0;right:0;padding:40px 20px 20px;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 100%);color:#fff}.sheet-title-overlay h2{font-size:1.5rem;font-weight:700;margin:0 0 4px}.sheet-title-overlay p{font-size:1rem;opacity:.9;margin:0}.sheet-body{padding:20px}.sheet-description{font-size:.95rem;line-height:1.6;color:#4b5563;margin:0 0 16px}.sheet-meta{display:flex;gap:16px;margin-bottom:16px}.meta-item{display:flex;align-items:center;gap:6px;font-size:.9rem;color:#6b7280}.meta-icon{font-size:1.1rem}.sheet-facts{background:#f9fafb;border-radius:12px;padding:16px}.sheet-facts h4{font-size:.9rem;font-weight:600;color:#374151;margin:0 0 12px}.sheet-facts ul{margin:0;padding-left:20px}.sheet-facts li{font-size:.85rem;color:#6b7280;margin-bottom:6px}.sheet-footer{padding:16px 20px;border-top:1px solid #e5e7eb}.cta-primary{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:14px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.cta-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.map-bottom-nav{position:fixed;bottom:0;left:0;right:0;height:70px;background:#fff;border-top:1px solid #e5e7eb;display:flex;justify-content:space-around;align-items:center;z-index:1000;padding-bottom:env(safe-area-inset-bottom)}.map-bottom-nav button{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;color:#9ca3af;font-size:.7rem;font-weight:500;cursor:pointer;padding:8px 16px;border-radius:12px;transition:all .2s}.map-bottom-nav button:hover{background:#c4b5fd1a}.map-bottom-nav button.active{color:#6366f1}.map-bottom-nav .nav-icon{font-size:1.4rem}.map-bottom-nav .nav-label{font-weight:600}.popup-content{padding:16px;max-width:280px}.popup-title{font-size:1.1rem;font-weight:600;color:#1f2937;margin:0 0 4px}.popup-subtitle{font-size:.9rem;color:#6b7280;margin:0 0 12px}.popup-image{width:100%;height:120px;object-fit:cover;border-radius:8px;margin-bottom:12px}.popup-description{font-size:.85rem;line-height:1.5;color:#4b5563;margin:0 0 12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.popup-cta-btn{width:100%;padding:10px 16px;background:linear-gradient(135deg,#c4b5fd,#a7e6e6);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.popup-cta-btn:hover{transform:translateY(-1px)}.custom-monument-marker{background:transparent;border:none}.marker-pin-photo{width:50px;height:50px;border-radius:50%;overflow:hidden;border:4px solid;box-shadow:0 4px 16px #0000004d;background:#fff;display:flex;align-items:center;justify-content:center}.marker-pin-photo img{width:100%;height:100%;object-fit:cover}.marker-pin-pointer{width:12px;height:12px;position:absolute;bottom:0;left:50%;transform:translate(-50%) rotate(45deg);margin-bottom:-6px;box-shadow:2px 2px 4px #0003}.custom-user-marker{background:transparent;border:none}.user-marker-pin{position:relative;width:24px;height:24px}.user-marker-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;background:#3b82f6;border:3px solid white;border-radius:50%;box-shadow:0 2px 8px #3b82f666;z-index:2}.user-marker-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;background:#3b82f64d;border-radius:50%;animation:pulse-ring 2s ease-out infinite}@keyframes pulse-ring{0%{transform:translate(-50%,-50%) scale(.8);opacity:1}to{transform:translate(-50%,-50%) scale(2);opacity:0}}.user-popup h4{font-size:1rem;color:#1f2937;margin:0 0 4px}.user-popup p{font-size:.85rem;color:#6b7280;margin:0}@media (max-width: 768px){.monument-drawer{max-width:100%}.monument-detail-sheet{max-height:50vh}.sheet-header{height:150px}}.map-page{background:var(--color-cream, #FDF8F3)}.map-header{background:linear-gradient(180deg,#fdf8f3fa,#fdf8f3f2);border-bottom:1px solid rgba(199,91,57,.15)}.map-header h1{font-family:var(--font-heading, "Playfair Display", serif);color:var(--color-charcoal, #2D2926)}.map-header .back-btn{color:var(--color-terracotta, #C75B39);font-weight:600}.list-toggle-btn{background:#c75b391a;color:var(--color-terracotta, #C75B39)}.list-toggle-btn:hover{background:#c75b3933}.status-pill.loading{background:#e8a83826;color:#c98e2a}.status-pill .spinner{border-color:#e8a8384d;border-top-color:#e8a838}.status-pill.success{background:#1d6b5c26;color:#1d6b5c}.status-pill.error{background:#c75b3926;color:#c75b39}.drawer-header{border-bottom:1px solid rgba(199,91,57,.15)}.drawer-header h2{font-family:var(--font-heading, "Playfair Display", serif);color:var(--color-charcoal, #2D2926)}.close-drawer{background:var(--color-sand, #F5E6D3);color:var(--color-charcoal, #2D2926)}.close-drawer:hover{background:var(--color-sand-light, #FBF4EB)}.monument-list-item:hover{background:#c75b390d}.monument-list-item.selected{background:linear-gradient(135deg,#c75b391a,#e8a8381a);border:1px solid rgba(199,91,57,.3)}.monument-info h3{color:var(--color-charcoal, #2D2926)}.monument-distance span.nearby{background:linear-gradient(135deg,#c75b39,#e8a838);color:#fff}.monument-detail-sheet{border-radius:32px 32px 0 0;box-shadow:0 -8px 40px #2d292626}.close-sheet{background:#2d2926b3}.sheet-title-overlay h2{font-family:var(--font-heading, "Playfair Display", serif)}.sheet-description{color:var(--color-warm-gray, #6B5E54)}.sheet-facts{background:var(--color-sand-light, #FBF4EB);border:1px solid rgba(199,91,57,.1)}.sheet-facts h4{color:var(--color-charcoal, #2D2926)}.sheet-footer{border-top:1px solid rgba(199,91,57,.15)}.cta-primary{background:linear-gradient(135deg,#c75b39,#e8a838);border-radius:var(--radius-full, 50px);box-shadow:0 8px 30px #c75b3959}.cta-primary:hover{box-shadow:0 12px 40px #c75b3973}.map-bottom-nav{background:linear-gradient(180deg,#fdf8f3fa,#fdf8f3);border-top:1px solid rgba(199,91,57,.15)}.map-bottom-nav button:hover{background:#c75b391a}.map-bottom-nav button.active{color:var(--color-terracotta, #C75B39)}.popup-title{font-family:var(--font-heading, "Playfair Display", serif);color:var(--color-charcoal, #2D2926)}.popup-cta-btn{background:linear-gradient(135deg,#c75b39,#e8a838);border-radius:var(--radius-lg, 12px)}.user-marker-dot{background:var(--color-deep-blue, #1E4D6B);box-shadow:0 2px 8px #1e4d6b66}.user-marker-pulse{background:#1e4d6b4d}.map-bottom-nav button[data-tutorial=map-nav]:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:16px;pointer-events:none}.onboarding{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);padding-bottom:calc(var(--space-6) + var(--safe-bottom));overflow:hidden}.onboarding__bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.onboarding__pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cpolygon points='40,0 50,35 80,40 50,45 40,80 30,45 0,40 30,35' fill='white' opacity='0.05'/%3E%3C/svg%3E");background-size:80px 80px;z-index:1;pointer-events:none}.onboarding__skip{position:absolute;top:var(--space-4);right:var(--space-4);top:calc(var(--space-4) + var(--safe-top));padding:var(--space-2) var(--space-4);background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-full);color:#fff;font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;z-index:10;transition:all var(--transition-fast)}.onboarding__skip:hover{background:#ffffff4d}.onboarding__slides{position:relative;z-index:5;flex:1;display:flex;align-items:center;justify-content:center;width:100%;max-width:400px;touch-action:pan-y}.onboarding__slide{text-align:center;color:#fff;padding:var(--space-4)}.onboarding__icon{width:100px;height:100px;margin:0 auto var(--space-6);background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;box-shadow:0 10px 40px #0003}.onboarding__title{font-family:var(--font-heading);font-size:var(--text-4xl);font-weight:var(--font-bold);line-height:1.1;margin:0 0 var(--space-2) 0;white-space:pre-line}.onboarding__subtitle{font-family:var(--font-arabic);font-size:var(--text-xl);opacity:.8;margin:0 0 var(--space-4) 0}.onboarding__description{font-size:var(--text-lg);line-height:var(--leading-relaxed);opacity:.9;max-width:320px;margin:0 auto}.onboarding__steps{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-6);align-items:center}.onboarding__step{display:flex;align-items:center;gap:var(--space-3);background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--space-3) var(--space-5);border-radius:var(--radius-full)}.onboarding__step-number{width:28px;height:28px;background:#fff;color:var(--color-terracotta);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:var(--text-sm)}.onboarding__step-text{font-weight:var(--font-medium)}.onboarding__dots{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin:var(--space-8) 0;z-index:5}.onboarding__dot{background:none;border:none;padding:var(--space-1);cursor:pointer;color:#fff6;transition:all var(--transition-fast)}.onboarding__dot--active{color:#fff}.onboarding__button{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;max-width:300px;padding:var(--space-4) var(--space-6);background:#fff;color:var(--color-terracotta);border:none;border-radius:var(--radius-full);font-size:var(--text-lg);font-weight:var(--font-bold);cursor:pointer;box-shadow:var(--shadow-xl);z-index:5}.onboarding__button-icon{font-size:var(--text-xl);transition:transform var(--transition-fast)}.onboarding__button:hover .onboarding__button-icon{transform:translate(4px)}.onboarding__hint{position:absolute;bottom:calc(var(--space-4) + var(--safe-bottom));left:50%;transform:translate(-50%);font-size:var(--text-sm);color:#fff9;z-index:5}@media (max-width: 640px){.onboarding__title{font-size:var(--text-3xl)}.onboarding__icon{width:80px;height:80px;font-size:2.5rem}.onboarding__description{font-size:var(--text-base)}}@media (min-height: 800px){.onboarding__icon{width:120px;height:120px;font-size:3.5rem;margin-bottom:var(--space-8)}.onboarding__title{font-size:var(--text-5xl)}}.coach-mark{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-spotlight);pointer-events:all}.coach-mark__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.coach-mark__ring{position:absolute;border:3px solid var(--color-terracotta);border-radius:var(--radius-xl);pointer-events:none}.coach-mark__tooltip{position:absolute;width:300px;background:#fff;border-radius:var(--radius-2xl);padding:var(--space-5);box-shadow:var(--shadow-2xl);z-index:10}.coach-mark__tooltip--centered{position:fixed;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important}.coach-mark__tooltip:before{content:"";position:absolute;width:16px;height:16px;background:#fff;transform:rotate(45deg)}.coach-mark__tooltip--centered:before{display:none}.coach-mark__progress{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.coach-mark__progress-dot{width:8px;height:8px;border-radius:50%;background:var(--color-warm-gray-lighter);transition:all var(--transition-fast)}.coach-mark__progress-dot.active{background:var(--color-terracotta);transform:scale(1.2)}.coach-mark__progress-dot.completed{background:var(--color-saffron)}.coach-mark__title{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-charcoal);margin:0 0 var(--space-2) 0}.coach-mark__description{font-size:var(--text-base);color:var(--color-warm-gray);line-height:var(--leading-relaxed);margin:0 0 var(--space-4) 0}.coach-mark__actions{display:flex;align-items:center;justify-content:space-between}.coach-mark__skip{background:none;border:none;color:var(--color-warm-gray);font-size:var(--text-sm);cursor:pointer;padding:var(--space-2);margin-left:calc(var(--space-2) * -1)}.coach-mark__skip:hover{color:var(--color-charcoal)}.coach-mark__nav{display:flex;gap:var(--space-2)}.coach-mark__btn{padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-fast)}.coach-mark__btn--prev{background:var(--color-sand);color:var(--color-charcoal)}.coach-mark__btn--prev:hover{background:var(--color-sand-light)}.coach-mark__btn--next{background:var(--gradient-moroccan);color:#fff}.coach-mark__btn--next:hover{box-shadow:var(--shadow-terracotta)}@media (max-width: 640px){.coach-mark__tooltip{width:calc(100vw - var(--space-8));max-width:320px}}.profile-page{min-height:100vh;background:var(--color-cream);padding-bottom:90px}.profile-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fdf8f3f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(199,91,57,.15)}.profile-header h1{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--color-charcoal);margin:0}.profile-header .back-btn{background:none;border:none;font-size:1rem;color:var(--color-terracotta);cursor:pointer;padding:8px 0;font-weight:600}.header-spacer{width:60px}.profile-content{padding:20px;max-width:600px;margin:0 auto}.profile-section{margin-bottom:24px}.profile-section h2{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--color-charcoal);margin:0 0 16px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-header h2{margin:0}.clear-btn{background:none;border:none;color:var(--color-terracotta);font-size:.9rem;font-weight:500;cursor:pointer}.pass-card{background:#fff;border-radius:var(--radius-2xl);padding:20px;box-shadow:var(--shadow-md);border:2px solid var(--color-warm-gray-lighter)}.pass-card.active{border-color:var(--color-emerald);background:linear-gradient(135deg,#1d6b5c0d,#fff)}.pass-card.expired{border-color:var(--color-saffron);background:linear-gradient(135deg,#e8a8380d,#fff)}.pass-status{display:flex;align-items:center;gap:8px;margin-bottom:16px}.status-icon{font-size:1.2rem}.status-text{font-size:.9rem;font-weight:600;color:var(--color-charcoal)}.pass-card.active .status-text{color:var(--color-emerald)}.pass-card.expired .status-text{color:var(--color-saffron)}.pass-details{margin-bottom:16px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--color-warm-gray-lighter)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:.9rem;color:var(--color-warm-gray)}.detail-value{font-size:.9rem;font-weight:600;color:var(--color-charcoal)}.detail-value.code{font-family:monospace;font-size:.85rem;background:var(--color-sand-light);padding:4px 8px;border-radius:var(--radius-md)}.pass-actions{display:flex;gap:12px}.no-pass-card{background:#fff;border-radius:var(--radius-2xl);padding:32px 20px;text-align:center;box-shadow:var(--shadow-md);border:2px dashed var(--color-warm-gray-lighter)}.no-pass-icon{font-size:3rem;margin-bottom:16px}.no-pass-card h3{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--color-charcoal);margin:0 0 8px}.no-pass-card p{font-size:.9rem;color:var(--color-warm-gray);margin:0 0 20px;line-height:1.5}.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;background:var(--gradient-moroccan);color:#fff;border:none;border-radius:var(--radius-xl);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-terracotta)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #c75b3959}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;background:var(--color-sand-light);color:var(--color-charcoal);border:none;border-radius:var(--radius-xl);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover{background:var(--color-sand)}.visit-list{background:#fff;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-md)}.visit-item{display:flex;align-items:center;gap:14px;padding:16px;border-bottom:1px solid var(--color-warm-gray-lighter)}.visit-item:last-child{border-bottom:none}.visit-icon{font-size:1.5rem}.visit-info h4{font-size:.95rem;font-weight:600;color:var(--color-charcoal);margin:0 0 4px}.visit-info p{font-size:.85rem;color:var(--color-warm-gray);margin:0}.empty-state{background:#fff;border-radius:var(--radius-2xl);padding:32px 20px;text-align:center;box-shadow:var(--shadow-md)}.empty-icon{font-size:2rem;display:block;margin-bottom:12px}.empty-state p{font-size:.9rem;color:var(--color-warm-gray);margin:0}.settings-list{background:#fff;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-md)}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--color-warm-gray-lighter)}.setting-item:last-child{border-bottom:none}.setting-info{display:flex;align-items:center;gap:14px}.setting-icon{font-size:1.5rem}.setting-info h4{font-size:.95rem;font-weight:600;color:var(--color-charcoal);margin:0 0 2px}.setting-info p{font-size:.8rem;color:var(--color-warm-gray);margin:0}.toggle{position:relative;display:inline-block;width:52px;height:28px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-warm-gray-lighter);transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:var(--shadow-sm)}.toggle input:checked+.toggle-slider{background:var(--gradient-moroccan)}.toggle input:checked+.toggle-slider:before{transform:translate(24px)}.language-select{padding:10px 40px 10px 16px;background:var(--color-sand-light);border:none;border-radius:var(--radius-lg);font-size:.9rem;font-weight:500;color:var(--color-charcoal);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236B5E54'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px}.about-card{background:#fff;border-radius:var(--radius-2xl);padding:20px;box-shadow:var(--shadow-md)}.app-info{text-align:center;padding-bottom:16px;border-bottom:1px solid var(--color-warm-gray-lighter);margin-bottom:16px}.app-info h3{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--color-charcoal);margin:0 0 4px}.app-info p{font-size:.9rem;color:var(--color-warm-gray);margin:0 0 8px}.version{font-size:.8rem;color:var(--color-warm-gray-light)}.about-links{display:flex;justify-content:center;gap:24px}.about-link{display:flex;flex-direction:column;align-items:center;gap:6px;text-decoration:none;color:var(--color-warm-gray);font-size:.85rem;font-weight:500;transition:color var(--transition-fast)}.about-link span{font-size:1.3rem}.about-link:hover{color:var(--color-terracotta)}.profile-bottom-nav{position:fixed;bottom:0;left:0;right:0;height:70px;background:linear-gradient(180deg,#fdf8f3f2,#fdf8f3);border-top:1px solid rgba(199,91,57,.15);display:flex;justify-content:space-around;align-items:center;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.profile-bottom-nav button{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;color:var(--color-warm-gray);font-size:.7rem;font-weight:500;cursor:pointer;padding:8px 16px;border-radius:var(--radius-xl);transition:all var(--transition-fast)}.profile-bottom-nav button:hover{background:#c75b391a}.profile-bottom-nav button.active{color:var(--color-terracotta)}.profile-bottom-nav .nav-icon{font-size:1.4rem}.profile-bottom-nav .nav-label{font-weight:600}:root{--color-terracotta: #C75B39;--color-terracotta-light: #E07B5C;--color-terracotta-dark: #A44A2D;--color-saffron: #E8A838;--color-saffron-light: #F5C35A;--color-saffron-dark: #C98E2A;--color-deep-blue: #1E4D6B;--color-deep-blue-light: #2A6A8F;--color-deep-blue-dark: #153A52;--color-emerald: #1D6B5C;--color-emerald-light: #278F7A;--color-emerald-dark: #154F44;--color-sand: #F5E6D3;--color-sand-light: #FBF4EB;--color-cream: #FDF8F3;--color-white: #FFFFFF;--color-gold: #D4A853;--color-gold-light: #E8C478;--color-burnt-orange: #D4763D;--color-cobalt: #2B5F9E;--color-rose: #C97B84;--color-charcoal: #2D2926;--color-warm-gray: #6B5E54;--color-warm-gray-light: #9A8D82;--color-warm-gray-lighter: #D4CCC4;--color-success: #2D8B6F;--color-warning: #E8A838;--color-error: #C75B39;--color-info: #2B5F9E;--gradient-moroccan: linear-gradient(135deg, var(--color-terracotta) 0%, var(--color-saffron) 100%);--gradient-sunset: linear-gradient(135deg, var(--color-burnt-orange) 0%, var(--color-gold) 100%);--gradient-ocean: linear-gradient(135deg, var(--color-deep-blue) 0%, var(--color-cobalt) 100%);--gradient-oasis: linear-gradient(135deg, var(--color-emerald) 0%, var(--color-deep-blue) 100%);--gradient-sand: linear-gradient(180deg, var(--color-cream) 0%, var(--color-sand) 100%);--gradient-warm-overlay: linear-gradient(135deg, rgba(199, 91, 57, .1) 0%, rgba(232, 168, 56, .1) 100%);--font-heading: "Playfair Display", "Georgia", serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-arabic: "Amiri", "Scheherazade New", serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.2;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--tracking-tighter: -.05em;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-3xl: 2rem;--radius-full: 9999px;--radius-arch: 50% 50% 0 0 / 30% 30% 0 0;--shadow-sm: 0 1px 2px rgba(45, 41, 38, .05);--shadow-md: 0 4px 6px rgba(45, 41, 38, .07), 0 2px 4px rgba(45, 41, 38, .06);--shadow-lg: 0 10px 15px rgba(45, 41, 38, .1), 0 4px 6px rgba(45, 41, 38, .05);--shadow-xl: 0 20px 25px rgba(45, 41, 38, .1), 0 10px 10px rgba(45, 41, 38, .04);--shadow-2xl: 0 25px 50px rgba(45, 41, 38, .15);--shadow-terracotta: 0 10px 30px rgba(199, 91, 57, .25);--shadow-saffron: 0 10px 30px rgba(232, 168, 56, .25);--shadow-gold: 0 10px 30px rgba(212, 168, 83, .25);--shadow-inner: inset 0 2px 4px rgba(45, 41, 38, .1);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--transition-slower: .5s ease;--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--ease-out-back: cubic-bezier(.34, 1.56, .64, 1);--z-base: 0;--z-dropdown: 10;--z-sticky: 20;--z-fixed: 30;--z-modal-backdrop: 40;--z-modal: 50;--z-popover: 60;--z-tooltip: 70;--z-toast: 80;--z-spotlight: 90;--z-max: 100;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}@media (prefers-color-scheme: dark){:root.auto-dark{--color-cream: #1A1714;--color-sand: #2D2926;--color-charcoal: #F5E6D3;--color-warm-gray: #D4CCC4;--color-warm-gray-light: #9A8D82}}.text-terracotta{color:var(--color-terracotta)}.text-saffron{color:var(--color-saffron)}.text-deep-blue{color:var(--color-deep-blue)}.text-emerald{color:var(--color-emerald)}.text-gold{color:var(--color-gold)}.text-charcoal{color:var(--color-charcoal)}.text-warm-gray{color:var(--color-warm-gray)}.bg-terracotta{background-color:var(--color-terracotta)}.bg-saffron{background-color:var(--color-saffron)}.bg-sand{background-color:var(--color-sand)}.bg-cream{background-color:var(--color-cream)}.bg-gradient-moroccan{background:var(--gradient-moroccan)}.bg-gradient-sunset{background:var(--gradient-sunset)}.bg-gradient-ocean{background:var(--gradient-ocean)}.bg-gradient-oasis{background:var(--gradient-oasis)}.font-heading{font-family:var(--font-heading)}.font-body{font-family:var(--font-body)}.font-arabic{font-family:var(--font-arabic)}.shadow-terracotta{box-shadow:var(--shadow-terracotta)}.shadow-gold{box-shadow:var(--shadow-gold)}input,select,textarea{font-size:16px!important}.safe-area-top{padding-top:max(var(--space-4),env(safe-area-inset-top))}.safe-area-bottom{padding-bottom:max(var(--space-4),env(safe-area-inset-bottom))}.scroll-container{-webkit-overflow-scrolling:touch;overflow-y:auto}.full-height{min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh}button,a,[role=button]{-webkit-tap-highlight-color:transparent}.fixed-element{position:fixed;-webkit-transform:translateZ(0);transform:translateZ(0)}@supports not ((-webkit-backdrop-filter: blur(10px)) or (backdrop-filter: blur(10px))){.glass-bg{background:#fdf8f3fa!important}.hero-badge,.hero-stats,.onboarding__skip,.status-badge{background:#fffffff2!important}}.backdrop-blur{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@supports not (gap: 1rem){.flex-gap>*+*{margin-left:var(--space-4)}.flex-gap-vertical>*+*{margin-top:var(--space-4)}}.will-animate{-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.gpu-render{will-change:transform,opacity;contain:layout paint}html,body{overscroll-behavior-y:none}.allow-overscroll{overscroll-behavior-y:auto}.scroll-y{touch-action:pan-y}.scroll-x{touch-action:pan-x}.no-touch-action{touch-action:none}input[type=text],input[type=email],input[type=password],input[type=search],input[type=tel],input[type=url],textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:var(--radius-md)}button,input[type=button],input[type=submit]{-webkit-appearance:none;-moz-appearance:none;appearance:none}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B5E54' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}video{-webkit-playsinline:true;playsinline:true}img{-webkit-user-drag:none;user-drag:none}body.modal-open{position:fixed;width:100%;overflow:hidden}@supports (-webkit-touch-callout: none){.full-screen{height:100%;min-height:-webkit-fill-available}}@supports not (display: grid){.grid-fallback{display:flex;flex-wrap:wrap}.grid-fallback>*{flex:0 0 calc(50% - var(--space-4));margin:calc(var(--space-4) / 2)}}@supports not selector(:focus-visible){button:focus,a:focus,input:focus,select:focus{outline:2px solid var(--color-gold);outline-offset:2px}}svg{flex-shrink:0}@media print{.no-print{display:none!important}.print-break{page-break-before:always}}@media (prefers-contrast: high){:root{--color-terracotta: #A04020;--color-saffron: #CC8800;--color-charcoal: #000000;--color-warm-gray: #333333}button,a{border:2px solid currentColor}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-cream);min-height:100vh;overflow-x:hidden;color:var(--color-charcoal);line-height:var(--leading-normal)}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--font-bold);line-height:var(--leading-tight);color:var(--color-charcoal)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}a{color:var(--color-terracotta);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-terracotta-dark)}:focus-visible{outline:2px solid var(--color-gold);outline-offset:2px}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-gold);outline-offset:2px}::selection{background:var(--color-saffron);color:var(--color-charcoal)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-sand-light)}::-webkit-scrollbar-thumb{background:var(--color-warm-gray-lighter);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-warm-gray-light)}@supports (-webkit-touch-callout: none){body,#root{min-height:-webkit-fill-available}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.swipeable{touch-action:pan-y}.no-select{-webkit-user-select:none;user-select:none}.gpu-accelerated{transform:translateZ(0);will-change:transform}.arabic-text{font-family:var(--font-arabic);direction:rtl}
