/* ═══════════════════════════════════════════════════
   SOUL STRINGS PROJECT — Shared Stylesheet
   Import on every page: <link rel="stylesheet" href="ssp-styles.css">
═══════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --orange:#E8601C;
  --orange-lt:#f07840;
  --orange-dim:rgba(232,96,28,0.18);
  --navy:#1D4E7A;
  --navy-lt:#2a6499;
  --navy-dim:rgba(29,78,122,0.25);
  --green:#22c55e;
  --green-dim:rgba(34,197,94,0.15);
  --red:#ef4444;
  --red-dim:rgba(239,68,68,0.15);
  --yellow:#fbbf24;
  --yellow-dim:rgba(251,191,36,0.15);
  --cream:#F0E8D8;
  --cream-dim:#c8bfaf;
  --muted:#8a8070;
  --text-secondary:#b0a898;
  --dark:#1a1710;
  --dark2:#222018;
  --dark3:#2c2820;
  --dark4:#343028;
  --border:rgba(232,96,28,0.28);
  --border2:rgba(240,232,216,0.12);
  --border3:rgba(240,232,216,0.18);
  --r:6px;
}

html{scroll-behavior:smooth}
body{background:var(--dark);color:var(--cream);font-family:'Barlow',sans-serif;font-weight:400;line-height:1.75;overflow-x:hidden}

::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--dark)}
::-webkit-scrollbar-thumb{background:var(--orange);border-radius:2px}

/* ── TYPOGRAPHY ── */
h1,h2,h3{font-family:'Bebas Neue',sans-serif;letter-spacing:1px}
p{color:var(--cream-dim);line-height:1.85}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  display:flex;align-items:center;justify-content:space-between;
  padding:0.7rem 2.5rem;
  background:rgba(26,23,16,0.97);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;cursor:pointer}
.nav-logo img{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid var(--orange)}
.nav-brand{display:flex;flex-direction:column;line-height:1.1}
.nav-brand-name{font-family:'Bebas Neue',sans-serif;font-size:1.25rem;letter-spacing:2px;color:var(--cream)}
.nav-brand-tag{font-size:0.58rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--orange)}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{color:var(--text-secondary);font-size:0.82rem;text-decoration:none;letter-spacing:1px;font-weight:500;transition:color 0.2s;text-transform:uppercase;cursor:pointer}
.nav-links a:hover,.nav-links a.active{color:var(--cream)}
.nav-cta{background:var(--orange);color:#fff;padding:0.5rem 1.4rem;border:none;border-radius:var(--r);font-size:0.8rem;font-weight:600;cursor:pointer;letter-spacing:0.5px;font-family:'Barlow',sans-serif;transition:background 0.2s;text-decoration:none;white-space:nowrap}
.nav-cta:hover{background:var(--orange-lt)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{width:24px;height:2px;background:var(--cream);display:block;transition:all 0.3s;border-radius:2px}

/* ── BUTTONS ── */
.btn-orange{background:var(--orange);color:#fff;padding:0.8rem 2.2rem;border:none;border-radius:var(--r);font-family:'Barlow',sans-serif;font-weight:600;font-size:0.9rem;cursor:pointer;letter-spacing:0.5px;transition:background 0.2s,transform 0.15s;display:inline-flex;align-items:center;gap:6px}
.btn-orange:hover{background:var(--orange-lt);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--cream);padding:0.8rem 2.2rem;border:1.5px solid rgba(240,232,216,0.25);border-radius:var(--r);font-family:'Barlow',sans-serif;font-weight:400;font-size:0.9rem;cursor:pointer;transition:border-color 0.2s,transform 0.15s;display:inline-flex;align-items:center;gap:6px}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-1px)}

/* ── SECTIONS ── */
section{padding:5rem 3rem}
.section-tag{font-size:0.72rem;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:0.5rem;font-weight:600}
.section-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.4rem,5vw,3.8rem);letter-spacing:1.5px;line-height:1;margin-bottom:0.8rem;color:var(--cream)}
.section-title em{color:var(--orange);font-style:normal}
.divider{width:50px;height:2px;background:linear-gradient(90deg,var(--orange),transparent);margin:1rem 0 2.2rem}

/* ── FORM ELEMENTS ── */
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:1rem}
.form-group label{font-size:0.75rem;letter-spacing:0.5px;text-transform:uppercase;color:var(--text-secondary);font-weight:600}
.form-group label .req{color:var(--orange);margin-left:2px}
.form-group input,
.form-group select,
.form-group textarea{
  background:var(--dark4);
  border:1px solid var(--border3);
  border-radius:var(--r);
  padding:0.78rem 1rem;
  color:var(--cream);
  font-family:'Barlow',sans-serif;
  font-size:0.92rem;
  font-weight:400;
  outline:none;
  transition:border-color 0.2s,background 0.2s;
  width:100%;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{border-color:var(--orange);background:var(--dark3)}
.form-group input::placeholder,
.form-group textarea::placeholder{color:var(--muted)}
.form-group select option{background:var(--dark3);color:var(--cream)}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:0.2rem 0.7rem;border-radius:100px;font-size:0.7rem;font-weight:600}
.badge-pending{background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(251,191,36,0.35)}
.badge-paid{background:var(--green-dim);color:var(--green);border:1px solid rgba(34,197,94,0.35)}
.badge-failed{background:var(--red-dim);color:var(--red);border:1px solid rgba(239,68,68,0.35)}
.badge-active{background:var(--green-dim);color:var(--green);border:1px solid rgba(34,197,94,0.35)}
.badge-inactive{background:var(--red-dim);color:var(--red);border:1px solid rgba(239,68,68,0.35)}
.badge-manual{background:var(--orange-dim);color:var(--orange);border:1px solid rgba(232,96,28,0.35)}
.badge-group{background:var(--navy-dim);color:#5b9fd4;border:1px solid rgba(29,78,122,0.4)}
.badge-expired{background:rgba(100,100,100,0.2);color:var(--muted);border:1px solid rgba(140,140,140,0.25)}

/* ── FOOTER ── */
footer{
  background:var(--dark);
  border-top:1px solid var(--border);
  padding:2rem 3rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:0.8rem;
}
.footer-logo{display:flex;align-items:center;gap:10px}
.footer-logo img{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1.5px solid var(--orange)}
.footer-brand{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:2px;color:var(--cream)}
.footer-copy{font-size:0.78rem;color:var(--muted)}
.footer-links{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-links a{font-size:0.78rem;color:var(--muted);text-decoration:none;transition:color 0.2s;cursor:pointer}
.footer-links a:hover{color:var(--orange)}

/* ── TOAST ── */
.toast{position:fixed;bottom:2rem;right:2rem;background:var(--dark3);border:1px solid var(--border);border-radius:var(--r);padding:0.85rem 1.4rem;font-size:0.85rem;z-index:9999;opacity:0;transform:translateY(10px);transition:all 0.3s;pointer-events:none;max-width:320px}
.toast.show{opacity:1;transform:translateY(0)}
.toast.success{border-color:rgba(34,197,94,0.5);color:#4ade80}
.toast.error{border-color:rgba(239,68,68,0.5);color:#f87171}
.toast.info{border-color:var(--border);color:var(--cream)}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.82);z-index:500;display:none;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex}
.modal{background:var(--dark2);border:1px solid var(--border);border-radius:12px;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:1px;margin-bottom:1.2rem;padding-bottom:0.6rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;color:var(--cream)}
.modal-close-btn{background:none;border:none;color:var(--muted);font-size:1.3rem;cursor:pointer;line-height:1}
.modal-close-btn:hover{color:var(--red)}

/* ── POLICY PAGES ── */
.policy-wrap{max-width:820px;margin:0 auto;padding:8rem 2rem 5rem}
.policy-hero{margin-bottom:3rem}
.policy-tag{font-size:0.72rem;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:0.5rem;font-weight:600}
.policy-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.4rem,5vw,3.8rem);letter-spacing:1.5px;line-height:1;margin-bottom:0.8rem;color:var(--cream)}
.policy-meta{font-size:0.8rem;color:var(--muted);margin-top:0.5rem}
.policy-body h2{font-family:'Bebas Neue',sans-serif;font-size:1.45rem;letter-spacing:1px;color:var(--cream);margin:2.5rem 0 0.8rem;padding-bottom:0.5rem;border-bottom:1px solid var(--border2)}
.policy-body h3{font-size:1rem;font-weight:600;color:var(--cream);margin:1.5rem 0 0.5rem}
.policy-body p{color:var(--cream-dim);font-size:0.94rem;line-height:1.95;margin-bottom:1rem}
.policy-body ul,.policy-body ol{color:var(--cream-dim);font-size:0.94rem;line-height:1.95;margin-bottom:1rem;padding-left:1.5rem}
.policy-body li{margin-bottom:0.4rem}
.policy-body a{color:var(--orange);text-decoration:none}
.policy-body a:hover{text-decoration:underline}
.highlight-box{background:var(--dark3);border:1px solid var(--border);border-radius:var(--r);padding:1.3rem 1.6rem;margin:1.5rem 0}
.highlight-box p{margin:0;font-size:0.92rem;color:var(--cream-dim)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  nav{padding:0.75rem 1.8rem}
}
@media(max-width:900px){
  nav{padding:0.75rem 1.2rem}
  .nav-links{display:none}
  .hamburger{display:flex}
  .nav-links.open{
    display:flex;flex-direction:column;
    position:fixed;top:64px;left:0;right:0;
    background:rgba(26,23,16,0.99);
    padding:1.5rem 1.5rem;gap:0.8rem;
    border-bottom:1px solid var(--border);
    z-index:299;
  }
  .nav-links.open a{font-size:1rem;padding:0.4rem 0;border-bottom:1px solid var(--border2)}
  .nav-links.open li:last-child a{border-bottom:none}
  section{padding:3rem 1.2rem}
  footer{flex-direction:column;text-align:center;padding:1.5rem 1.2rem;gap:0.8rem}
  .footer-links{justify-content:center}
  .policy-wrap{padding:7rem 1.2rem 3rem}
  .policy-body h2{font-size:1.3rem}
}
@media(max-width:540px){
  nav{padding:0.7rem 1rem}
  .nav-logo .nav-brand-tag{display:none}
  .nav-cta{padding:0.45rem 1rem;font-size:0.75rem}
}
