:root{--pc-primary:#040051;--app-header-h:72px}
body{background:#ffffff}
.navbar-brand{font-weight:600}
.card-title{font-weight:600}
.form-required::after{content:" *";color:#dc3545}
.table-actions{display:flex;gap:.5rem}
.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh;position:relative}
.app-shell.sidebar-collapsed{grid-template-columns:80px 1fr}
.sidebar{background:linear-gradient(180deg,#040051,#09007a);color:#fff;display:flex;flex-direction:column;padding:1.25rem;position:sticky;top:0;min-height:100vh;height:100vh;transition:left .2s ease;border-radius:24px;box-shadow:0 10px 30px rgba(4,0,81,.25)}
.sidebar.collapsed{padding:1rem}
.brand{display:flex;align-items:center;gap:.75rem;padding:.5rem 0 1rem 0}
.brand .brand-logo-img{height:32px;width:auto;border-radius:8px;background:rgba(255,255,255,.18);padding:4px}
.brand .collapse-toggle{margin-left:auto}
.brand-logo{display:inline-flex;width:32px;height:32px;border-radius:8px;background:rgba(255,255,255,.22);align-items:center;justify-content:center;font-weight:700;color:#fff}
.brand-name{font-weight:600}
.sidebar.collapsed .brand-name{display:none}
.sidebar.collapsed .brand{justify-content:space-between;gap:.5rem}
.sidebar.collapsed .brand .collapse-toggle{margin-left:0}
.sidebar.collapsed .brand .brand-logo-img{display:none}
.sidebar-nav{display:flex;flex-direction:column;gap:.35rem;flex:1;overflow-y:auto;overflow-x:hidden;padding-right:.25rem}
.sidebar-nav .nav-link{color:#e5eaff;padding:.65rem .85rem;border-radius:.8rem;text-decoration:none;display:flex;align-items:center}
.sidebar-nav .nav-link .nav-text{margin-left:.5rem}
.sidebar-nav .nav-link .nav-badge{margin-left:auto;background:#ef4444;color:#fff;border-radius:9999px;font-size:.7rem;padding:.1rem .4rem;line-height:1}
.sidebar-nav .nav-link:hover{background:rgba(255,255,255,.12);color:#fff}
.sidebar-nav .nav-link.active{background:#fff;color:#040051}
.sidebar-group{display:flex;flex-direction:column;gap:.25rem}
.sidebar-group-toggle{background:rgba(255,255,255,.1);color:#fff;border:0;border-radius:.8rem;padding:.6rem .85rem;display:flex;align-items:center;justify-content:space-between;font-weight:600}
.sidebar-group-toggle:hover{background:rgba(255,255,255,.18)}
.sidebar-group-toggle .bi{font-size:.85rem}
.sidebar-submenu{display:none;flex-direction:column;gap:.25rem;padding-left:.25rem}
.sidebar-group.open .sidebar-submenu{display:flex}
.sidebar-submenu .nav-link{padding-left:2rem;font-size:.95rem}
.sidebar-submenu .nav-link .bi{font-size:.95rem;opacity:.9}
.sidebar.collapsed .sidebar-nav .nav-link{justify-content:center;padding:.6rem}
.sidebar.collapsed .sidebar-nav .nav-link .nav-text{display:none}
.sidebar.collapsed .sidebar-group-toggle{justify-content:center}
.sidebar.collapsed .sidebar-group-toggle .group-text{display:none}
.sidebar.collapsed .sidebar-submenu{display:none}
.sidebar-foot{margin-top:auto}
.sidebar.collapsed .sidebar-foot{display:none}
.storage{background:rgba(255,255,255,.08);padding:.75rem;border-radius:.75rem}
.storage-title{font-size:.85rem;color:#e5eaff}
.progress{height:8px;border-radius:9999px;background:rgba(255,255,255,.18);overflow:hidden;margin:.25rem 0}
.progress-bar{height:100%;background:#7dd3fc}
.storage-info{font-size:.8rem;color:#e5eaff}
.app-main{background:#f4f9ff;padding-top:var(--app-header-h)}
.app-main{grid-column:2;grid-row:1}
.app-header{background:#fff;border-bottom:1px solid #e6e9f5;position:fixed;top:0;left:280px;width:calc(100% - 280px);z-index:1025}
.app-shell.sidebar-collapsed .app-header{left:80px;width:calc(100% - 80px)}
.app-header-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;max-width:1200px;margin:0 auto;width:100%}
.app-header .search .form-control{border-radius:9999px;background:#eef2ff;border:1px solid #e0e7ff;max-width:360px}
.app-header .search{position:relative}
.settings-sticky{position:sticky;top:0;z-index:1020;background:#fff;border-bottom:1px solid #e6e9f5;padding:.5rem 0}
.search-suggestions{position:absolute;left:0;right:0;top:calc(100% + 6px);background:#fff;border:1px solid #e6e9f5;border-radius:.75rem;box-shadow:0 8px 24px rgba(20,40,120,.08);display:none;z-index:1040}
.search-suggestions-item{padding:.5rem .75rem;border-bottom:1px solid #f0f2f9;cursor:pointer}
.search-suggestions-item:last-child{border-bottom:none}
.search-suggestions-item:hover{background:#f7fbff}
.header-actions .user-chip{background:#fff;border:1px solid #e6e9f5;border-radius:9999px;padding:.4rem .8rem;font-size:.9rem}
.header-actions{display:flex;align-items:center;gap:.75rem;position:relative}
.sidebar-backdrop{position:fixed;inset:0;display:none!important}
.notif-bell{position:relative;background:#fff;border:1px solid #e6e9f5;border-radius:9999px;padding:.35rem .6rem}
.notif-bell .bi{font-size:1.1rem;color:#040051}
.notif-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;border-radius:9999px;font-size:.7rem;padding:.1rem .35rem}
.notif-menu{position:absolute;right:0;top:48px;background:#fff;border:1px solid #e6e9f5;border-radius:.75rem;box-shadow:0 8px 24px rgba(20,40,120,.08);min-width:260px;display:none;z-index:1040}
.notif-item{padding:.65rem .75rem;border-bottom:1px solid #f0f2f9}
.notif-item:last-child{border-bottom:none}
.notif-tools{padding:.65rem .75rem;border-bottom:1px solid #f0f2f9;display:flex;flex-direction:column;gap:.5rem}
.notif-confirm{background:#f8fafc;border:1px solid #e6e9f5;border-radius:.6rem;padding:.5rem}
.app-content{padding:1.5rem;max-width:1200px;margin:0 auto;background:#fff}
.app-content-wide{max-width:100%;padding-left:1rem;padding-right:1rem}
.card.shadow-sm{border:none;border-radius:1.25rem;box-shadow:0 10px 30px rgba(31,118,230,.08)}
.table{--bs-table-bg:transparent;border-color:#e8ecf7}
.table thead th{color:#6b7280;border-bottom:1px solid #e6e9f5}
.table tbody tr{background:#fff;border-bottom:1px solid #eef2f9}
.table tbody tr:hover{background:#f7fbff}
.table td,.table th{padding:1rem}
@media(max-width:992px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-100%;top:0;bottom:0;width:260px;z-index:1040}
  .sidebar.open{left:0}
  .sidebar-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:saturate(140%) blur(1px);display:none;z-index:1039}
  .sidebar.open ~ .sidebar-backdrop{display:block}
  .app-main{margin-left:0;padding-top:var(--app-header-h)}
  .app-main{grid-column:1;grid-row:auto}
  .app-header{left:0;width:100%}
  .app-header-inner{padding:.75rem 1rem}
  .app-header .search .form-control{max-width:60vw}
  .app-content{padding:1rem}
}
.pricing-hero h2{font-weight:700}
.pricing-hero{position:relative;overflow:hidden;padding:6rem 0}
.pricing-hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(1200px 600px at 15% 0%, rgba(255,213,0,.25) 0%, rgba(255,213,0,0) 60%),
  radial-gradient(800px 800px at 85% 90%, rgba(255,255,255,.12) 0%, rgba(255,255,255,0) 60%);
mix-blend:screen;pointer-events:none}
.pricing-hero h2{font-weight:800;letter-spacing:.5px}
.pricing-hero h2::after{content:"";display:block;width:96px;height:4px;background:#FFD500;border-radius:9999px;margin:.5rem auto 0}
.pricing-hero p{max-width:720px;margin:.75rem auto 0;color:rgba(255,255,255,.88)!important}
.pricing-grid{margin-top:4rem}
.pricing-grid .plan-card{background:#fff;border:1px solid #e6eff7;border-radius:1.25rem;padding:1.5rem;box-shadow:0 14px 36px rgba(17,24,39,.08);transition:transform .2s ease, box-shadow .2s ease;position:relative;text-align:center}
.pricing-grid .plan-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(20,40,120,.09)}
.plan-header{display:flex;flex-direction:column;align-items:center}
.plan-header .plan-icon{width:80px;height:80px;border-radius:9999px;border:1px solid #f1f5f9;background:#fff;object-fit:contain}
.plan-name{font-weight:800;font-size:1.25rem;margin-top:.5rem;text-transform:uppercase;letter-spacing:.02em}
.plan-price{font-weight:800;color:#0f172a;font-size:1.2rem}
.plan-desc{color:#6b7280}
.plan-benefits{list-style:none;padding-left:0;margin:0}
.plan-benefits li{display:flex;align-items:center;gap:.5rem;padding:.35rem 0;color:#374151;justify-content:flex-start}
.plan-benefits .bi{color:#10b981}
.offer-banner{position:absolute;top:-12px;left:0;right:0;background:#292d77;color:#fff;padding:.35rem;font-weight:700;border-top-left-radius:1rem;border-top-right-radius:1rem}
.plan-card.featured{border:2px solid #292d77;box-shadow:0 16px 30px rgba(20,40,120,.12)}
.badge-offer{position:absolute;top:-14px;left:12px;background:#ffc000;color:#000;font-weight:800;border:2px solid #000;border-radius:9999px;padding:.25rem .6rem;display:flex;align-items:center;gap:.35rem;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.badge-offer .bi{color:#000}
.btn-cta{background:#fff004;border-color:#fff004;color:#292d77;text-transform:uppercase;font-weight:700;letter-spacing:.02em}
.btn-cta:hover{filter:brightness(.95);color:#fff}
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
.login-left{display:flex;align-items:center;justify-content:flex-start;padding:4rem 6vw;background:#fff}
.login-card{width:100%;max-width:420px;margin-left:0}
.login-right{position:relative;overflow:hidden}
.login-right::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.25))}
.login-bg{position:absolute;inset:0;background-size:cover;background-position:center right}
.login-title{font-weight:600;margin-bottom:1rem}
.login-link{display:inline-block;margin:.5rem 0;color:#040051;text-decoration:none}
.btn-gradient{background:linear-gradient(90deg,#2f2aa5,#040051);color:#fff;border:none}
.btn-pill{border-radius:9999px}
.btn-gradient:hover{filter:brightness(.95);color:#fff}
@media (min-width: 992px){
  .pricing-grid .row>[class*="col-"] .plan-card{height:100%}
}
.login-logo{max-width:160px;width:100%;height:auto}
.login-form .form-control{border-radius:.6rem;background:#eef2ff;border:1px solid #e0e7ff}
.login-form .form-control:focus{box-shadow:0 0 0 .2rem rgba(99,102,241,.2);border-color:#6366f1}
.accent-top{height:4px;background:#5b5cf0}
@media(max-width:992px){.login-wrap{grid-template-columns:1fr}.login-right{display:none}.login-left{padding:3rem 1.25rem}}
.landing-hero{position:relative;min-height:68vh;display:flex;align-items:center;padding:4rem 0;background:linear-gradient(180deg,#0f172a,#111827);color:#fff;overflow:hidden}
.landing-hero .container{position:relative;z-index:2}
.landing-hero .hero-content{max-width:960px;margin:0 auto}
.landing-hero .hero-title{font-weight:800;letter-spacing:.5px}
.hero-topbar{position:fixed;top:0;left:0;right:0;height:96px;background:#ffc000;color:#111827;display:flex;align-items:center;z-index:1000;box-shadow:0 2px 12px rgba(0,0,0,.12);border-bottom-left-radius:22px;border-bottom-right-radius:22px;overflow:hidden}
.@supports not ((backdrop-filter: blur(10px))) {.hero-topbar{background:#ffc000}}
.landing-hero{padding-top:6.5rem}
.hero-login{color:#111827;text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:.4rem}
.hero-login{border:1px solid #111827;border-radius:.6rem;padding:.35rem .75rem;background:transparent}
.hero-login:hover{color:#000;filter:brightness(.97)}
.hero-brand{display:flex;align-items:center;gap:.75rem}
.hero-brand-img{height:56px;width:auto;display:block;border-radius:10px;background:transparent;padding:0;box-shadow:none;border:none}
.hero-topbar .search .form-control{border-radius:9999px;background:#eef2ff;border:1px solid #e0e7ff}
.hero-topbar .search{position:relative}
.hero-menu-btn{display:none}
.hero-mobile-menu{display:none}
@media(max-width:576px){
  .hero-topbar .container{position:relative;justify-content:center}
  .hero-topbar{overflow:visible}
  .hero-topbar{z-index:1000}
  .hero-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid #111827;border-radius:.6rem;background:transparent;color:#111827;position:absolute;left:12px;top:50%;transform:translateY(-50%);z-index:1001}
  .hero-brand{margin:0 auto}
  .hero-brand-img{margin:0 auto;display:block}
  .hero-topbar .container>div:last-child{position:absolute;right:12px;top:50%;transform:translateY(-50%);z-index:1001}
  .hero-login{display:none}
  .hero-mobile-menu{display:block;position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--pc-primary);padding:1rem 1.25rem;box-shadow:none;z-index:999999;transform:translateX(-100%);transition:transform .25s ease;overflow-y:auto}
  .hero-mobile-menu.open{transform:translateX(0)}
  .hero-mobile-menu a{display:block;padding:.8rem 0;color:#ffffff;text-decoration:none;font-weight:800}
  .hero-mobile-menu a:hover{text-decoration:underline}
  .hero-mobile-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.35);backdrop-filter:saturate(140%) blur(1px);display:none;z-index:999998}
  .hero-mobile-backdrop.open{display:block}
  .hero-close-btn{position:absolute;top:12px;right:12px;background:#dc2626;color:#fff;border:none;border-radius:.6rem;padding:.4rem .6rem;font-weight:800;box-shadow:0 2px 8px rgba(0,0,0,.25)}
  .hero-close-btn .bi{color:#fff}
}
body.mm-open{overflow:hidden}
.search-hit{outline:2px solid #FFD500;outline-offset:2px;border-radius:.5rem;background:rgba(255,213,0,.15)}
.hero-login{color:#111827;text-decoration:none;font-weight:600}
.hero-login:hover{text-decoration:underline}
.hero-nav .hero-link{color:#111827;text-decoration:none;font-weight:600;opacity:.9}
.hero-nav .hero-link:hover{opacity:1;text-decoration:underline}
.sobre-hero{position:relative;background:linear-gradient(135deg,#0e1b4d,#152e6e);color:#fff;overflow:hidden}
.sobre-hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 400px at 15% 10%, rgba(59,130,246,.22) 0%, rgba(59,130,246,0) 60%),
  radial-gradient(700px 700px at 85% 80%, rgba(255,255,255,.12) 0%, rgba(255,255,255,0) 60%);mix-blend:screen}
.sobre-hero h2{font-weight:800;letter-spacing:.5px}
.sobre-hero h2::after{content:"";display:block;width:96px;height:4px;background:#FFD500;border-radius:9999px;margin:.5rem auto 0}
.sobre-hero{padding:5rem 0}
.sobre-hero .sobre-hero-content{text-align:center;position:relative;z-index:2}
.sobre-hero-brand{position:absolute;top:16px;left:16px;display:flex;align-items:center;gap:.5rem;z-index:3}
.sobre-hero-brand-img{height:96px;width:auto;border-radius:10px;background:rgba(255,255,255,.18);padding:4px;display:block}
@media(max-width:576px){
  .sobre-hero-brand-img{height:64px}
}
.sobre-title{font-weight:800;font-size:2rem;margin-bottom:.5rem}
.sobre-sub{opacity:.9}
.sobre-main{background:#fff}
.hero-topbar + .sobre-main{margin-top:110px}
.hero-topbar + .pricing-hero{margin-top:110px}
.hero-topbar ~ .sobre-main{margin-top:110px}
.hero-topbar ~ .pricing-hero{margin-top:110px}
.hero-topbar + .pf-hero{margin-top:110px}
.hero-topbar ~ .pf-hero{margin-top:110px}
.header-logo{display:flex;align-items:center}
.header-logo-img{height:48px;width:auto;object-fit:contain;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:4px}
.header-logo-placeholder{height:48px;width:120px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border:1px dashed #d1d5db;border-radius:8px;color:#6b7280;font-size:.875rem}
.logos-marquee{position:relative;overflow:hidden;border:1px solid #ecebf6;border-radius:1rem;background:#fff;padding:.75rem 1.25rem;display:flex;align-items:center;justify-content:center}
.logos-track{display:flex;align-items:center;gap:2rem;width:max-content;min-width:200%;animation:logosSlide 24s linear infinite;will-change:transform}
.logo-item{flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.logo-img{height:52px;width:auto;object-fit:contain}
@keyframes logosSlide{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}
.sobre-section{padding:3rem 0}
.sobre-card{background:#fff;border:1px solid #e6e9f5;border-radius:1rem;padding:1.25rem;box-shadow:0 8px 24px rgba(17,24,39,.06);text-align:center;height:100%}
.sobre-card:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(17,24,39,.1)}
.sobre-icon{width:56px;height:56px;border-radius:9999px;background:#eef2ff;border:1px solid #e0e7ff;margin:0 auto 8px auto;display:flex;align-items:center;justify-content:center}
.sobre-icon .bi{color:#040051;font-size:1.3rem}
.sobre-card-title{font-weight:700}
.sobre-card-desc{color:#6b7280}
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}
.city-chip{background:#f8fafc;border:1px solid #e6e9f5;border-radius:.8rem;padding:.6rem .8rem;display:flex;align-items:center;gap:.4rem;color:#111827}
.city-chip .bi{color:#dc2626}
.sobre-video{max-width:900px;margin:0 auto}
.sobre-video-el{width:100%;height:auto;aspect-ratio:16/9;border-radius:1rem;background:#000;display:block}
.sobre-video-placeholder{width:100%;aspect-ratio:16/9;border:1px dashed #e6e9f5;border-radius:1rem;display:flex;align-items:center;justify-content:center;color:#6b7280;background:#f9fbff}
.sobre-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.sobre-card{background:#fff;border:1px solid #ecebf6;border-radius:1rem;padding:.5rem;box-shadow:0 8px 24px rgba(17,24,39,.06);transition:transform .2s ease, box-shadow .2s ease}
.sobre-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(17,24,39,.12)}
.sobre-carousel{border-radius:1rem;overflow:hidden;box-shadow:0 12px 32px rgba(17,24,39,.12)}
.sobre-empty{background:#fff;border:1px dashed #e6e9f5;border-radius:1rem;padding:2rem;text-align:center}
.hero-title{font-weight:800;font-size:2.2rem;line-height:1.2;margin-bottom:1rem}
.hero-title{background-image:linear-gradient(90deg,#fff,#9bbcff,#fff004,#ff7b7b);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:heroGrad 8s linear infinite}
.@keyframes heroGrad{}
@keyframes heroGrad{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.hero-logo{max-width:260px;width:100%;height:auto;display:block;margin-bottom:1rem}
.hero-sub{font-size:1.05rem;color:#e5e7eb;max-width:900px}
.landing-hero .hero-content{text-align:center}
.landing-hero .hero-title{color:#fff;background-image:none;-webkit-background-clip:initial;background-clip:initial;animation:none;text-shadow:0 2px 12px rgba(0,0,0,.35),0 4px 24px rgba(0,0,0,.25)}
.landing-hero .hero-title{margin-top:3.5rem}
.hero-title.type-caret{position:relative;display:inline-block}
.hero-title.type-caret::after{content:"";display:inline-block;width:2px;height:1.1em;background:#fff;margin-left:6px;animation:caretBlink 1s steps(1) infinite;vertical-align:baseline}
@keyframes caretBlink{50%{opacity:0}}
.hero-desc{font-size:.95rem;color:#cbd5e1;max-width:900px;margin-top:.5rem}
.hero-actions{display:flex;gap:.75rem;margin-top:1.25rem}
.hero-highlights{display:flex;gap:1rem;margin-top:1rem;list-style:none;padding:0}
.hero-highlights li{display:flex;align-items:center;gap:.5rem;border:1px solid #e6e9f5;border-radius:9999px;padding:.35rem .7rem;color:#6b7280;opacity:.6;transition:opacity .3s ease, transform .3s ease}
.hero-highlights li.active{opacity:1;transform:scale(1.02);color:#fff;border-color:#040051}
.hero-highlights .bi{color:#fff004}
.btn-cta-primary{background:linear-gradient(90deg,#2f2aa5,#040051);color:#fff;border:none;box-shadow:0 0 0 0 rgba(4,0,81,.5);animation:pulseGlow 2.8s infinite}
.btn-cta-primary:hover{box-shadow:0 0 0 12px rgba(13,110,253,.08),0 12px 24px rgba(13,110,253,.35)}
@keyframes pulseGlow{0%{box-shadow:0 0 0 0 rgba(13,110,253,.6)}70%{box-shadow:0 0 0 16px rgba(13,110,253,0)}100%{box-shadow:0 0 0 0 rgba(13,110,253,0)}}
.btn-cta-secondary{background:transparent;border:1px solid #e6e9f5;color:#0f172a}
.btn-cta-primary:hover{filter:brightness(.95);color:#fff}
.btn-cta-secondary:hover{background:#0f172a;color:#fff}
.btn-cta-danger{background:linear-gradient(90deg,#ff3b30,#b91c1c);color:#fff;border:none;box-shadow:0 8px 18px rgba(239,68,68,.25)}
.btn-cta-danger:hover{filter:brightness(.95);color:#fff;box-shadow:0 10px 22px rgba(239,68,68,.35)}
.hero-bg{position:absolute;inset:0;background-image:radial-gradient(ellipse at 20% 30%,rgba(58,96,255,.35),transparent 40%),radial-gradient(ellipse at 80% 70%,rgba(255,123,123,.25),transparent 40%),linear-gradient(180deg,rgba(13,27,59,.2),rgba(13,27,59,.6));background-size:cover;background-position:center right;opacity:.5;z-index:1;transform:translate3d(0,0,0);pointer-events:none}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(110%) contrast(105%);}
.hero-slider{position:absolute;inset:0;z-index:1}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;background-size:cover;background-position:center}
.hero-slide::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.35);pointer-events:none}
.hero-slide.active{opacity:1}
.hero-slide video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.landing-hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,213,0,.14) 1px,transparent 1px);background-size:20px 20px;opacity:.18;z-index:0}
.landing-hero::after{content:"";position:absolute;inset:0;background:rgba(255,255,255,0);z-index:0;pointer-events:none}
.whatsapp-fab{position:fixed;right:16px;bottom:16px;background:#25D366;color:#fff;border:none;border-radius:9999px;padding:.6rem .9rem;display:inline-flex;align-items:center;gap:.4rem;z-index:2000;text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.25)}
.whatsapp-fab:hover{filter:brightness(.95);color:#fff}
.landing-section{padding:4rem 0;background:#fafafa}
.landing-section.alt{background:#fff}
.section-head h2{font-weight:800;position:relative;padding-bottom:.4rem}
.section-head h2::after{content:"";position:absolute;left:0;bottom:0;width:80px;height:4px;background:#FFD500;border-radius:9999px}
.about-card{background:#fff;border:1px solid #ecebf6;border-radius:1rem;padding:1.25rem;box-shadow:0 8px 24px rgba(17,24,39,.06);text-align:left;height:100%}
.about-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(17,24,39,.12)}
.about-icon{width:44px;height:44px;border-radius:9999px;background:#fff3b0;color:#111827;display:inline-flex;align-items:center;justify-content:center;margin-bottom:.5rem;box-shadow:0 2px 6px rgba(0,0,0,.08)}
.about-title{font-weight:700}
.about-desc{color:#6b7280}
.about-icon{width:48px;height:48px;border-radius:9999px;background:#eef2ff;border:1px solid #e0e7ff;display:flex;align-items:center;justify-content:center;margin-bottom:.5rem}
.about-icon .bi{color:#040051}
.about-title{font-weight:700}
.about-desc{color:#6b7280}
.store-card{background:rgba(255,255,255,.9);backdrop-filter:saturate(120%) blur(4px);border:1px solid #e6e9f5;border-radius:1rem;padding:1.25rem;text-align:center;box-shadow:0 8px 24px rgba(20,40,120,.06);transform-style:preserve-3d;transition:transform .2s ease, box-shadow .2s ease}
.store-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(20,40,120,.12)}
.store-photo{width:100%;height:140px;border-radius:.8rem;object-fit:cover;margin-bottom:.6rem;border:1px solid #e6e9f5}
/* Oval photo for store cards on landing */
.landing-section .store-card img.store-photo{width:220px;height:auto;aspect-ratio:3/2;border-radius:50%;object-fit:cover;margin:0 auto .75rem;display:block}
@media(max-width:576px){
  .landing-section .store-card img.store-photo{width:180px;aspect-ratio:3/2}
}
.portfolio-grid .book-card{position:relative;background:#fff;border:1px solid #e6e9f5;border-radius:1rem;padding:.75rem;box-shadow:0 12px 32px rgba(17,24,39,.12);transition:transform .25s ease, box-shadow .25s ease;perspective:1000px}
.portfolio-grid .book-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(17,24,39,.18)}
.portfolio-grid .book-card::before{content:"";position:absolute;left:10px;top:10px;bottom:10px;width:10px;border-radius:6px;background:linear-gradient(90deg, rgba(0,0,0,.06), rgba(0,0,0,0));pointer-events:none}
.portfolio-grid .book-photo{width:100%;aspect-ratio:4/3;border-radius:.8rem;object-fit:cover;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
.portfolio-grid .book-caption{margin-top:.5rem;color:#6b7280;font-size:.9rem}
.book-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;z-index:2000}
.book-lightbox.open{display:flex}
.book-lightbox img{max-width:92vw;max-height:92vh;border-radius:1rem;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.book-lightbox .controls{position:fixed;inset:auto 0 24px 0;display:flex;justify-content:center;gap:.75rem}
.book-lightbox .btn{background:#fff;border:1px solid #e6e9f5;border-radius:.6rem;padding:.4rem .8rem;color:#111827}
.store-icon{width:56px;height:56px;border-radius:9999px;background:#dc2626;border:1px solid #dc2626;margin:0 auto 8px auto;display:flex;align-items:center;justify-content:center}
.store-icon .bi{color:#FFD500;font-size:1.4rem}
.store-name{font-weight:700}
.store-desc{color:#6b7280;font-size:.95rem;margin-top:.25rem}
.feat-card{background:rgba(255,255,255,.9);backdrop-filter:saturate(120%) blur(4px);border:1px solid #e6e9f5;border-radius:1rem;padding:1.25rem;height:100%;text-align:center;box-shadow:0 8px 24px rgba(20,40,120,.06);transform-style:preserve-3d;transition:transform .2s ease, box-shadow .2s ease}
.feat-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(20,40,120,.12)}
.feat-card{cursor:pointer}
.feat-icon{width:56px;height:56px;border-radius:9999px;background:#fff;border:1px solid #e6e9f5;margin:0 auto 8px auto;display:flex;align-items:center;justify-content:center}
.feat-icon .bi{color:#ef4444;font-size:1.3rem}
.feat-title{font-weight:700}
.feat-desc{color:#6b7280;font-size:.95rem}
.adv-item{display:flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.9);backdrop-filter:saturate(120%) blur(3px);border:1px solid #e6e9f5;border-radius:.8rem;padding:.8rem}
.adv-item .bi{color:#10b981}
.adv-row{cursor:grab}
.adv-row.dragging{opacity:.6}
.adv-handle{cursor:grab}
.touch-card{background:rgba(255,255,255,.9);backdrop-filter:saturate(120%) blur(4px);border:1px solid #e6e9f5;border-radius:1rem;padding:1.25rem;height:100%;box-shadow:0 8px 24px rgba(20,40,120,.06);transform-style:preserve-3d;transition:transform .2s ease, box-shadow .2s ease}
.touch-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(20,40,120,.12)}
.touch-icon .bi{color:#040051;font-size:1.3rem}
.touch-title{font-weight:700;margin-top:.35rem}
.touch-desc{color:#6b7280}
.mini-plan-card{background:rgba(255,255,255,.92);backdrop-filter:saturate(120%) blur(5px);border:1px solid #e6e9f5;border-radius:1rem;padding:1.25rem;box-shadow:0 8px 24px rgba(20,40,120,.06);position:relative;transform-style:preserve-3d;transition:transform .2s ease, box-shadow .2s ease}
.mini-plan-card.featured{border:2px solid #292d77;box-shadow:0 16px 30px rgba(20,40,120,.12)}
.mini-plan-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(20,40,120,.12)}
.mini-offer{position:absolute;top:-10px;left:0;right:0;background:#292d77;color:#fff;font-weight:700;border-top-left-radius:1rem;border-top-right-radius:1rem;padding:.25rem;text-align:center}
.mini-plan-head{display:flex;align-items:center;gap:.75rem}
.mini-plan-name{font-weight:700}
.mini-plan-price{font-weight:800;color:#111827}
.landing-cta{padding:4rem 0;background:linear-gradient(180deg,#ffdf00,#ffb300);color:#111827;text-align:center}
.landing-cta h2{font-weight:800;margin-bottom:1rem}
.landing-cta .cta-actions{display:flex;gap:.75rem;justify-content:center}
/* Landing video */
.landing-video{max-width:720px;margin:0 auto}
.landing-video-el{width:100%;aspect-ratio:16/9;border-radius:1rem;background:#000;object-fit:contain;display:block}
@media (min-width:1200px){
  .landing-video{max-width:860px}
}
/* Landing footer */
.landing-foot{padding:3rem 0;background:#282e78;color:#fff}
.landing-foot .container{max-width:1400px}
.landing-foot .foot-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,3fr);gap:2rem;margin-bottom:1.5rem}
.landing-foot .foot-group a{display:block;color:#e6e9f5;text-decoration:none;margin:.3rem 0}
.landing-foot .foot-group a:hover{color:#fff;text-decoration:underline}
.landing-foot .foot-title{font-weight:800;margin-bottom:.5rem}
.landing-foot .foot-stores{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));column-gap:1.25rem;row-gap:.75rem;color:#e6e9f5;align-items:start;text-align:center}
.landing-foot .foot-stores .bi{color:#dc2626;margin-right:.25rem}
.landing-foot .foot-stores > div{display:flex;align-items:center;justify-content:center;gap:.35rem;line-height:1.35;margin:0}
.landing-foot .foot-bottom{display:flex;align-items:center;justify-content:space-between;border-top:1px solid #1f2937;padding-top:1rem;margin-top:.5rem}
.landing-foot .foot-brand{font-weight:800;font-size:1.1rem}
.landing-foot .foot-social{display:flex;gap:.75rem}
.landing-foot .foot-social a{color:#fff;font-size:1.25rem}
.landing-foot .foot-copy{color:#9ca3af;text-align:center;margin-top:.75rem}
.landing-foot .foot-copy a{color:#fff;font-weight:700;text-decoration:none}
.landing-foot .foot-copy a:hover{text-decoration:underline}
.contract-view{max-height:520px;overflow:auto;border:1px solid #e6e9f5;border-radius:.6rem;padding:1rem;background:#fff}
.calendar-table{border-color:#e6e9f5}
@media(max-width:576px){
  .landing-foot{padding:2rem 0}
  .landing-foot .foot-grid{grid-template-columns:1fr;gap:1rem}
  .landing-foot .foot-group{background:rgba(255,255,255,.06);border-radius:.8rem;padding:.75rem}
  .landing-foot .foot-title{margin-bottom:.25rem}
  .landing-foot .foot-stores{grid-template-columns:1fr;gap:.35rem}
  .landing-foot .foot-bottom{flex-direction:column;align-items:center;gap:.5rem;text-align:center}
  .landing-foot .foot-social{justify-content:center}
  .landing-foot .foot-copy{text-align:center}
}
.calendar-table thead th{background:linear-gradient(180deg,#fde8e8,#fee2e2);border:1px solid #f5d5d5;color:#7f1d1d;font-weight:600}
.calendar-table.calendar-table-strong thead th{background:#b91c1c;border:1px solid #991b1b;color:#fff}
.calendar-day{padding:.25rem}
.calendar-day .calendar-cell{background:#fff;border:1px solid #e6e9f5;border-radius:.6rem;min-height:140px;padding:.5rem;display:flex;flex-direction:column}
.calendar-day.calendar-empty .calendar-cell{background:#f9fbff;border-color:#eef1f7}
.calendar-day.is-weekend .calendar-cell{background:#f9fbff}
.calendar-day.is-today .calendar-cell{border-color:#2563eb;box-shadow:0 0 0 2px rgba(37,99,235,.15) inset}
.calendar-top{display:flex;justify-content:space-between;align-items:center}
.calendar-top .day-number{font-weight:600}
.calendar-top .day-count{color:#64748b;font-size:.875rem}
.calendar-top .full-date{color:#64748b;font-size:.75rem;margin-left:.5rem}
.calendar-events{margin-top:.25rem;display:flex;flex-direction:column;gap:.25rem;overflow:auto}
.calendar-event{background:#f8fafc;border:1px solid #e6e9f5;border-radius:.5rem;padding:.35rem .5rem;cursor:pointer}
.calendar-event .event-title{font-size:.875rem;font-weight:600;color:#111827}
.calendar-event .event-meta{font-size:.75rem;color:#64748b}
.calendar-event .badge{border-radius:9999px;font-weight:600}
.calendar-event .badge.bg-secondary{background:#b58900;color:#fff}
.calendar-event .badge.bg-danger{background:#dc2626;color:#fff}
.calendar-event .badge.bg-success{background:#16a34a;color:#fff}
.calendar-event .badge.bg-warning{background:#f59e0b;color:#fff}
/* Context menu */
.context-menu{position:absolute;background:#fff;border:1px solid #e6e9f5;border-radius:.6rem;box-shadow:0 10px 24px rgba(20,40,120,.12);min-width:200px;z-index:2000;padding:.25rem}
.context-menu .context-item{display:flex;align-items:center;gap:.5rem;padding:.45rem .6rem;cursor:pointer;border-radius:.5rem;color:#374151}
.context-menu .context-item:hover{background:#f7fbff}
.context-menu .context-sep{height:1px;background:#eef2ff;margin:.25rem 0}
/* Google-like calendar styling */
.calendar-table-google{border:0}
.calendar-table-google thead th{background:#fff;border:0;color:#374151;font-weight:600;padding:.5rem;border-bottom:1px solid #e5e7eb;text-transform:uppercase;font-size:.8rem}
.calendar-table-google tbody td{border:0;vertical-align:top}
.calendar-table-google .calendar-cell{border:1px solid #e5e7eb;border-radius:.4rem;min-height:180px;padding:.4rem;transition:box-shadow .15s ease,border-color .15s ease}
.calendar-table-google .calendar-cell:hover{box-shadow:0 2px 10px rgba(0,0,0,.06);border-color:#d1d5db}
.calendar-table-google .calendar-day.is-weekend .calendar-cell{background:#fcfdff}
.calendar-table-google .calendar-top{gap:.5rem}
.calendar-table-google .calendar-top .day-number{font-weight:700;color:#111827}
.calendar-table-google .calendar-day.is-today .day-number{background:#1a73e8;color:#fff;border-radius:9999px;padding:.1rem .4rem}
.calendar-table-google .calendar-top .full-date{color:#9ca3af}
.calendar-table-google .calendar-events{gap:.35rem}
.calendar-table-google .calendar-event{background:transparent;border:0;padding:.1rem .2rem}
.calendar-table-google .calendar-event .event-title{font-size:.82rem;font-weight:600}
.calendar-table-google .calendar-event .event-meta{font-size:.72rem;color:#6b7280}
.calendar-table-google .calendar-event .badge{display:inline-block;padding:.1rem .45rem;border-radius:9999px;font-size:.72rem}
.calendar-head-red thead th{background:#b91c1c!important;color:#fff!important;border-bottom:1px solid #991b1b!important}
.subscribe-card{background:rgba(255,255,255,.92);backdrop-filter:saturate(120%) blur(4px);border:1px solid #e6e9f5;border-radius:1.25rem;box-shadow:0 12px 36px rgba(20,40,120,.10)}
.subscribe-form .form-label{font-weight:600;color:#374151}
.subscribe-form .form-control{border-radius:.6rem;background:#eef2ff;border:1px solid #e0e7ff}
.subscribe-form .form-control:focus{box-shadow:0 0 0 .15rem rgba(99,102,241,.15);border-color:#6366f1}
.subscribe-form .input-group .form-control.bg-light{background:#f3f6ff;border-color:#e0e7ff}
.subscribe-header{background:linear-gradient(90deg,#2f2aa5,#040051);color:#fff;box-shadow:0 6px 18px rgba(13,27,59,.18);padding:.6rem 0}
.subscribe-header .brand-logo-img{height:40px;width:auto;border-radius:8px;background:rgba(255,255,255,.18);padding:4px}
.visits-map{height:380px;border:1px solid #e6e9f5;border-radius:.8rem}
.visits-grid-wrap{overflow-x:auto}
.visits-grid{display:flex;flex-direction:column;gap:.6rem;min-width:840px}
.visits-grid-header,.visits-grid-row{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr));gap:.75rem;align-items:center;padding:.6rem .75rem;border:1px solid #e6e9f5;border-radius:.6rem}
.visits-grid-header{background:#f8fafc;font-weight:600;color:#374151}
.visits-grid-row{background:#fff}
.visits-grid-empty{border:1px dashed #e6e9f5;border-radius:.6rem;padding:.8rem;color:#6b7280;text-align:center}
.visits-grid-pager{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}
.visits-grid-info{color:#6b7280;font-size:.9rem}
.chart-container{position:relative;height:280px;width:100%}
/* Portfolio new page */
.pf-hero{padding:5rem 0;background:linear-gradient(180deg,#0f172a,#111827);color:#fff;text-align:center}
.pf-title{font-weight:800;letter-spacing:.5px;margin-bottom:.4rem}
.pf-subtitle{color:#cbd5e1}
.pf-section{padding:2rem 0}
.pf-carousel{position:relative;overflow:hidden;border-radius:1rem;box-shadow:0 18px 40px rgba(17,24,39,.18);background:#0b1020}
.pf-track{display:flex;transition:transform .5s ease}
.pf-slide{min-width:100%;position:relative}
.pf-slide img{width:100%;height:58vh;object-fit:cover;display:block}
.pf-overlay{position:absolute;left:0;right:0;bottom:0;padding:1rem 1.25rem;background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));color:#fff}
.pf-overlay h3{margin:0 0 .25rem 0;font-size:1.25rem}
.pf-overlay p{margin:0;color:#e5e7eb}
.pf-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffffcc;border:1px solid #e6e9f5;border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;color:#111827}
.pf-nav.prev{left:12px}
.pf-nav.next{right:12px}
.pf-dots{position:absolute;left:0;right:0;bottom:10px;display:flex;gap:.5rem;justify-content:center}
.pf-dots button{width:8px;height:8px;border-radius:50%;border:none;background:#94a3b8;opacity:.7}
.pf-dots button.active{background:#f59e0b;opacity:1}
@media(max-width:576px){
  .pf-slide img{height:48vh}
}
.pf-filters{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1rem}
.pf-filter-btn{border:1px solid #e6e9f5;background:#fff;color:#111827;border-radius:.6rem;padding:.35rem .8rem;font-weight:600}
.pf-filter-btn.active{background:#111827;color:#fff;border-color:#111827}
.pf-grid{column-count:3;column-gap:1rem}
@media(max-width:992px){.pf-grid{column-count:2}}
@media(max-width:576px){.pf-grid{column-count:1}}
.pf-item{display:inline-block;width:100%;margin-bottom:1rem;position:relative;border-radius:.8rem;overflow:hidden;background:#0b1020;box-shadow:0 12px 28px rgba(17,24,39,.12);break-inside:avoid}
.pf-item img{width:100%;height:auto;display:block;object-fit:cover}
.pf-item .pf-overlay{position:absolute;left:0;right:0;bottom:0;padding:.6rem .8rem;background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));color:#fff;opacity:0;transition:opacity .2s ease}
.pf-item:hover .pf-overlay{opacity:1}
