:root{--nav-h:72px;--indigo:#4f46e5;--emerald:#10b981;--pink:#ec4899;--sky:#0ea5e9;--amber:#f59e0b;}
body{font-family:Inter,system-ui,-apple-system,'Segoe UI',Roboto,Arial;background:
linear-gradient(180deg, rgba(15,23,42,.02), rgba(15,23,42,0) 40%),
radial-gradient(1200px 600px at 85% -10%, rgba(79,70,229,.10), transparent),
radial-gradient(900px 500px at -10% 40%, rgba(16,185,129,.08), transparent),
radial-gradient(700px 350px at 110% 50%, rgba(236,72,153,.08), transparent);
padding-top:var(--nav-h);} 
/* Distinct hero background */
.hero-bg{background:
  radial-gradient(900px 500px at 10% -10%, rgba(14,165,233,.10), transparent),
  radial-gradient(700px 350px at 95% 10%, rgba(236,72,153,.10), transparent),
  linear-gradient(180deg,#ffffff 0%, #fbfdff 50%, #ffffff 100%);
  position:relative}
/* Soft alternating section background */
.bg-soft{background:
  linear-gradient(180deg,#f8fafc 0%, #ffffff 100%)}
section{scroll-margin-top:calc(var(--nav-h) + 18px);}
.navbar.fixed-top{background:rgba(255,255,255,.85)!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.06);transition:background-color .2s ease, box-shadow .2s ease, border-color .2s ease}
.navbar.fixed-top.scrolled{background:#fff!important;box-shadow:0 8px 30px rgba(2,6,23,.08);border-bottom-color:rgba(0,0,0,.08)}
.navbar .navbar-nav{gap:.25rem}
.navbar .nav-link{font-weight:600;color:#111;padding:.5rem .75rem;border:1px solid transparent;border-radius:.5rem;transition:color .15s ease, background-color .15s ease, border-color .15s ease;position:relative}
.navbar .nav-link:hover{color:var(--indigo);background:rgba(79,70,229,.06);border-color:rgba(79,70,229,.15)}
.navbar .nav-link.active{color:var(--indigo);background:rgba(79,70,229,.12);border-color:rgba(79,70,229,.25)}
.navbar .nav-link.active:after{display:none}
.navbar-brand-badge{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:.75rem;background:linear-gradient(135deg,var(--indigo),var(--emerald));}
.navbar-brand-title{font-size:1.25rem;line-height:1;font-weight:800}
.brand-slogan{margin-top:.2rem;display:inline-flex;align-items:center;gap:.4rem;font-weight:600;letter-spacing:.2px;font-size:.85rem}
.brand-slogan .slogan-caret{width:8px;height:1.1em;position:relative}
.brand-slogan .slogan-caret:after{content:"";position:absolute;left:2px;top:0;bottom:0;width:2px;background:currentColor;opacity:.8}
.brand-slogan .slogan-caret.blink:after{animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
/* Confetti hearts emitting from brand badge */
.navbar-brand-badge{position:relative;overflow:visible}
.navbar-brand-badge::after{content:"";position:absolute;inset:0}
.hearts{position:absolute;left:18px;top:18px;pointer-events:none}
.hearts span{position:absolute;font-size:11px;opacity:0;animation:float 3.8s ease-in infinite;}
.hearts span:nth-child(1){left:-4px;animation-delay:.2s}
.hearts span:nth-child(2){left:6px;animation-delay:1s}
.hearts span:nth-child(3){left:0;animation-delay:1.8s}
.hearts span:nth-child(4){left:10px;animation-delay:2.6s}
.hearts span:nth-child(5){left:-8px;animation-delay:3.4s}
.hearts span:nth-child(6){left:4px;animation-delay:4.2s}
.hearts span:nth-child(7){left:12px;animation-delay:5s}
@keyframes float{0%{transform:translateY(0) scale(.9);opacity:0}10%{opacity:1}70%{opacity:1}100%{transform:translateY(-26px) scale(1.2);opacity:0}}
.hero-title{font-weight:800;line-height:1.12;padding-bottom:.12em;background:linear-gradient(180deg,#0b0c10,#6b7280);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.hero-sub{max-width:52ch}
.badge-soft{display:inline-flex;align-items:center;gap:.5rem;border:1px solid rgba(0,0,0,.06);background:linear-gradient(135deg,#fff,rgba(255,255,255,.9));border-radius:999px;padding:.35rem .75rem;font-weight:600;box-shadow:0 6px 14px rgba(2,6,23,.06);margin-bottom:.75rem;white-space:nowrap}
.glass{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:rgba(255,255,255,.90);border:1px solid rgba(0,0,0,.06);border-radius:1.25rem;box-shadow:0 10px 30px rgba(2,6,23,.06);} 
.rounded-3xl{border-radius:1.25rem;}
.card-hover{transition:transform .2s ease, box-shadow .2s ease;}
.card-hover:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(79,70,229,.12);}
footer{background:#fafafa;border-top:1px solid #e5e7eb}
.site-footer .link-list a{display:inline-block;padding:.15rem 0}
.site-footer a{color:#111;text-decoration:none}
.site-footer a:visited{color:#111;text-decoration:none}
.site-footer .link-list a:focus,.site-footer .link-list a:hover{color:var(--indigo);text-decoration:none}
.site-footer .legal{border-top:1px solid #e5e7eb;background:#fdfdfd}
.site-footer .social-links a{width:34px;height:34px}
.attachments-list .list-group-item{background:transparent;border-color:#e5e7eb}
.attachments-list .list-group-item .btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center}
.footer-links a{color:#111;text-decoration:none}
.footer-links a:hover{color:var(--indigo);text-decoration:none}
footer .bottom{border-top:1px solid #e5e7eb}
.social-links a{width:40px;height:40px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #e5e7eb;background:linear-gradient(180deg,#fff,#fafafa);color:#111;transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, color .2s ease}
.social-links a:hover{transform:translateY(-2px);border-color:#111;color:#111;box-shadow:0 10px 24px rgba(2,6,23,.10)}
.social-links i{font-size:1rem}
.auth-modal .left{background:linear-gradient(180deg, rgba(79,70,229,.9), rgba(16,185,129,.9));color:#fff;border-top-left-radius:1rem;border-bottom-left-radius:1rem;}
.auth-modal .right{padding:1.25rem;}
/* Fix spacing utilities used by sections */
.py-6{padding-top:3rem!important;padding-bottom:3rem!important}
.py-7{padding-top:3.5rem!important;padding-bottom:3.5rem!important}
@media (min-width:768px){.py-md-7{padding-top:4rem!important;padding-bottom:4rem!important}}
/* Feature icon pill */
.icon-pill{width:48px;height:48px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg, var(--indigo), var(--sky));color:#fff;box-shadow:0 8px 22px rgba(79,70,229,.25)}
.icon-pill.indigo{background:linear-gradient(135deg, var(--indigo), var(--sky));color:#fff}
.icon-pill.emerald{background:linear-gradient(135deg, var(--emerald), var(--sky));color:#fff}
.icon-pill.pink{background:linear-gradient(135deg, var(--pink), var(--amber));color:#fff}
/* How it works - step cards */
.step-card{position:relative;border:1px solid #e5e7eb;border-radius:1rem;background:#fff;padding:1.5rem;box-shadow:0 10px 24px rgba(2,6,23,.06);transition:transform .2s ease, box-shadow .2s ease}
.step-card:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(2,6,23,.10)}
.step-icon{width:48px;height:48px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,var(--indigo),var(--sky));box-shadow:0 8px 22px rgba(79,70,229,.25)}
.step-card .lead-text{color:#334155}
@keyframes floatY{0%{transform:none}50%{transform:none}100%{transform:none}}

/* Scroll reveal */
[data-animate]{opacity:0;transform:translateY(12px);transition:opacity .45s ease, transform .45s ease}
[data-animate].in{opacity:1;transform:none}
/* Media previews in public jar page */
.media-preview img{max-height:320px;width:100%;object-fit:cover}
.media-preview video{max-height:360px;width:100%;height:auto;border-radius:.5rem}
.media-preview audio{width:100%}
/* Public jar viewer */
.jar-card .meta{display:flex;gap:.6rem;align-items:center;color:#6b7280;margin-top:.35rem}
.jar-card .meta .dot{width:3px;height:3px;border-radius:999px;background:#d1d5db;display:inline-block}
.attachment-pill{display:flex;align-items:center;gap:.5rem;border:1px solid #e5e7eb;border-radius:.75rem;padding:.5rem .75rem;background:#fff}
.attachment-pill i{color:var(--indigo)}
/* Quota badge */
.quota-badge{display:inline-flex;align-items:center;gap:.35rem;background:#f1f5f9;border:1px solid #e5e7eb;color:#334155;border-radius:999px;padding:.15rem .6rem;font-weight:600;font-size:.85rem}
.quota-badge .dot{width:6px;height:6px;border-radius:999px;background:var(--indigo)}
/* Public jar header polish */
.jar-icon-badge{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:.75rem;background:linear-gradient(135deg,var(--indigo),var(--emerald));box-shadow:0 8px 22px rgba(79,70,229,.18)}
.jar-title{font-weight:800;font-size:clamp(1.35rem,2.2vw+0.6rem,2rem);line-height:1.15;color:#111}
.jar-title-box{display:inline-block;border:1px solid rgba(0,0,0,.06);background:rgba(255,255,255,.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:1rem;padding:.6rem 1rem;box-shadow:0 10px 26px rgba(2,6,23,.08)}
.list-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;color:#6b7280;font-size:.875rem}
.jar-list .list-group-item{padding:0;border:none}
.jar-list .list-group-item:not(:last-child){margin-bottom:.5rem}
.jar-item{display:flex;justify-content:space-between;align-items:center;padding:.65rem 1rem;border:1px solid #e5e7eb;border-radius:.75rem;background:#fff;box-shadow:0 6px 14px rgba(2,6,23,.04);transition:transform .15s ease, box-shadow .15s ease}
.jar-item:hover{transform:translateY(-1px);box-shadow:0 10px 18px rgba(2,6,23,.08)}
.jar-item .title{display:flex;align-items:center;gap:.5rem;font-weight:600}
.jar-item .title i{color:var(--indigo)}
.jar-item .right{display:flex;align-items:center;gap:.6rem}
.status-badge{border:1px solid #e5e7eb;border-radius:999px;padding:.15rem .5rem;font-size:.75rem}
.status-open{background:rgba(16,185,129,.1);color:#065f46;border-color:rgba(16,185,129,.25)}
.status-locked{background:rgba(79,70,229,.08);color:#3730a3;border-color:rgba(79,70,229,.2)}
.date-pill{border:1px solid #e5e7eb;border-radius:999px;padding:.2rem .6rem;font-size:.8rem;background:#f8fafc;color:#334155;white-space:nowrap}

/* Dashboard tables mobile tweaks */
@media (max-width:576px){
  .table{font-size:.92rem}
  .table th:nth-child(2), .table td:nth-child(2){white-space:nowrap}
  .table th:nth-child(3), .table td:nth-child(3){display:none}
  .table th:last-child, .table td:last-child{text-align:right}
  .quota-badge{margin-top:.5rem}
  .jar-mobile-item{border:1px solid #e5e7eb;border-radius:.75rem;background:#fff;padding:.6rem .7rem;box-shadow:0 6px 14px rgba(2,6,23,.04)}
  /* Extra spacing below jars header on mobile */
  .jar-mobile-item:first-child{margin-top:.25rem}
}

@media (min-width:576px){
  .jars-actions .btn{width:auto !important}
}

/* Mobile optimizations */
@media (max-width:576px){
  .hero-title{font-size:clamp(1.6rem, 6vw + 0.6rem, 2.1rem)}
  .brand-slogan{font-size:.75rem}
  .glass{padding:1rem}
  .icon-pill,.step-icon{width:44px;height:44px;border-radius:10px}
  .social-links a{width:36px;height:36px}
  .navbar .nav-link{padding:.4rem .6rem}
  .navbar .btn{width:100%; margin-left:0!important}
  .navbar .nav-item + .nav-item{margin-top:.5rem}
  /* Auth modals: full-height and styled header */
  .auth-modal .modal-dialog{max-width:100%;margin:0;height:100%}
  .auth-modal .modal-content{min-height:100%;border-radius:0}
  .auth-modal .right{padding:1rem}
  .auth-modal .mobile-hero{display:flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,var(--indigo),var(--pink));color:#fff;border-radius:1rem;padding:.75rem 1rem;box-shadow:0 12px 28px rgba(79,70,229,.25)}
  .auth-modal .mobile-hero .badge-icon{width:38px;height:38px;border-radius:.75rem;background:rgba(255,255,255,.16);display:inline-flex;align-items:center;justify-content:center}
  .auth-modal .mobile-hero .badge-icon i{color:#fff}
  .auth-modal .input-group-lg .input-group-text{background:#f3f4f6;border:1px solid #e5e7eb}
  /* Prevent iOS Safari auto-zoom: keep input font-size >=16px while keeping compact height */
  .auth-modal .form-control{border-radius:.875rem;font-size:16px;line-height:1.2;padding:.55rem .7rem}
  .auth-modal .input-group-lg .form-control{font-size:16px;line-height:1.2;padding:.55rem .7rem}
  .auth-modal .btn.btn-lg{height:48px;border-radius:.875rem}
  /* Safe area for footer links (iOS/Android system bars) */
  html{background-clip:padding-box}
  .site-footer .legal{padding-bottom:calc(1rem + constant(safe-area-inset-bottom, 0px));padding-bottom:calc(1rem + env(safe-area-inset-bottom, 0px))}
  body{padding-bottom:constant(safe-area-inset-bottom, 0px);padding-bottom:env(safe-area-inset-bottom, 0px)}
}

/* Modal saving overlay */
.modal .modal-content{position:relative}
.modal-saving-overlay{position:absolute;inset:0;background:rgba(255,255,255,.75);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:5}
.modal-saving-overlay .box{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:.6rem .9rem;box-shadow:0 10px 24px rgba(2,6,23,.08)}
