/* ============================================================
   מועדון קפה שטמפפר — Cafe Shtampfer Loyalty Club
   DESIGN SYSTEM  ·  warm ivory · gold · espresso  ·  RTL-first
   Shared by: customer app, staff scanner, admin panel.
   © אופיר ברנס (Ofir Baranes) 2026 - כל הזכויות שמורות
   ============================================================ */

:root{
  /* surfaces */
  --bg:#f3ecdc;
  --bg-soft:#f8f2e6;
  --paper:#fffdf6;
  --paper-2:#fbf6ea;

  /* ink */
  --ink:#2a2017;
  --ink-soft:#6e6047;
  --ink-faint:#a4977f;

  /* gold */
  --gold:#b0884a;
  --gold-deep:#8a6a36;
  --gold-light:#dcbd80;
  --gold-bright:#e9cd92;

  /* espresso (dark surfaces: card, hero) */
  --espresso:#2a2017;
  --espresso-2:#1c150d;
  --espresso-3:#322619;

  /* feedback */
  --good:#3f9b6d;
  --good-deep:#2f7b54;
  --warn:#c9913c;
  --bad:#c2503f;

  /* lines + shadow */
  --line:rgba(120,92,48,.20);
  --line-strong:rgba(120,92,48,.38);
  --shadow-sm:0 6px 18px -10px rgba(60,40,16,.5);
  --shadow:0 18px 50px -28px rgba(60,40,16,.55);
  --shadow-lg:0 30px 70px -34px rgba(40,26,8,.6);

  /* type */
  --font-display:"Playfair Display","Frank Ruhl Libre",Georgia,serif;
  --font-accent:"Cormorant Garamond","Playfair Display",serif;
  --font-body:"Rubik","Heebo",system-ui,-apple-system,"Segoe UI",sans-serif;

  --maxw:1180px;
  --radius:18px;
  --radius-lg:26px;
  --ease:cubic-bezier(.22,1,.36,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
}

*{box-sizing:border-box;margin:0;padding:0;min-width:0}
html{
  scroll-behavior:smooth;-webkit-text-size-adjust:100%;
  /* hard guard: page can never scroll/drag sideways (RTL-safe) */
  overflow-x:hidden;
  overscroll-behavior-x:none;
}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  overscroll-behavior-x:none;
  overflow-wrap:break-word;
  min-height:100vh;
  min-height:100dvh;
}
/* media never forces horizontal overflow */
img,svg,video,canvas,iframe,picture{max-width:100%}
img{display:block}
a{color:inherit}
button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}
button{cursor:pointer;border:none;background:none}
h1,h2,h3,h4{line-height:1.2;font-weight:800}
[hidden]{display:none!important}

/* warm ambient backdrop */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(1100px 560px at 82% -10%, rgba(220,189,128,.22), transparent 60%),
    radial-gradient(820px 480px at -8% 8%, rgba(176,136,74,.12), transparent 55%),
    var(--bg);
}

/* ---------- layout primitives ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:20px}
.stack{display:flex;flex-direction:column;gap:16px}
.row{display:flex;align-items:center;gap:12px}
.spread{display:flex;align-items:center;justify-content:space-between;gap:12px}
.center{display:flex;align-items:center;justify-content:center}
.wrap{flex-wrap:wrap}
.grow{flex:1;min-width:0}
.muted{color:var(--ink-soft)}
.faint{color:var(--ink-faint)}
.tcenter{text-align:center}

/* ---------- brand lockup ---------- */
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}
.brand__mark{
  width:46px;height:46px;border-radius:13px;flex:0 0 auto;
  background:linear-gradient(135deg,#322619,#1c150d);
  display:grid;place-items:center;
  font-family:var(--font-display);font-weight:800;color:var(--gold-bright);font-size:1.5rem;
  box-shadow:inset 0 0 0 1px rgba(220,189,128,.25), var(--shadow-sm);
}
.brand__txt{display:flex;flex-direction:column;line-height:1.05;min-width:0}
.brand__name{font-family:var(--font-display);font-weight:800;font-size:1.18rem}
.brand__since{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-deep)}

/* ---------- buttons ---------- */
.btn{
  --bg-btn:var(--ink);--fg-btn:var(--paper);
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:700;font-size:1rem;letter-spacing:.01em;
  padding:14px 26px;border-radius:999px;
  background:var(--bg-btn);color:var(--fg-btn);
  transition:transform .25s var(--spring), box-shadow .3s var(--ease), filter .2s;
  box-shadow:var(--shadow-sm);white-space:nowrap;-webkit-tap-highlight-color:transparent;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.btn--gold{--bg-btn:linear-gradient(135deg,var(--gold-light),var(--gold-deep));--fg-btn:#3a2c12;
  box-shadow:0 14px 30px -14px rgba(138,106,54,.85)}
.btn--dark{--bg-btn:linear-gradient(135deg,#322619,#1c150d);--fg-btn:var(--gold-bright)}
.btn--good{--bg-btn:linear-gradient(135deg,#49ab7b,var(--good-deep));--fg-btn:#fff}
.btn--ghost{--bg-btn:transparent;--fg-btn:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line-strong)}
.btn--ghost:hover{background:rgba(176,136,74,.10)}
.btn--block{display:flex;width:100%}
.btn--lg{padding:17px 32px;font-size:1.08rem}
.btn--sm{padding:9px 16px;font-size:.86rem}

/* ---------- cards / panels ---------- */
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);padding:24px;
}
.panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.divider{height:1px;background:var(--line);border:0;margin:18px 0}
.gold-rule{height:3px;width:54px;border-radius:2px;background:linear-gradient(90deg,var(--gold-light),var(--gold-deep))}

.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 13px;border-radius:999px;
  font-size:.78rem;font-weight:600;background:rgba(176,136,74,.13);color:var(--gold-deep)}
.pill--good{background:rgba(63,155,109,.15);color:var(--good-deep)}
.pill--dark{background:rgba(42,32,23,.9);color:var(--gold-bright)}

/* ---------- forms ---------- */
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:.86rem;font-weight:600;color:var(--ink-soft)}
.field .hint{font-size:.76rem;color:var(--ink-faint)}
.input,.select,textarea.input{
  width:100%;background:var(--paper);border:1.5px solid var(--line-strong);
  border-radius:14px;padding:13px 15px;font-size:1rem;color:var(--ink);
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.input::placeholder{color:var(--ink-faint)}
.input:focus,.select:focus,textarea.input:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3.5px rgba(176,136,74,.16);background:#fff;
}
.input--lg{padding:16px 18px;font-size:1.06rem}
.check{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:.92rem;color:var(--ink-soft)}
.check input{margin-top:3px;width:18px;height:18px;accent-color:var(--gold-deep);flex:0 0 auto}

/* ---------- toast ---------- */
.toast-wrap{position:fixed;inset-block-start:18px;inset-inline:0;z-index:9999;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}
.toast{
  pointer-events:auto;background:var(--espresso);color:var(--paper);
  padding:13px 20px;border-radius:14px;box-shadow:var(--shadow-lg);
  font-weight:600;font-size:.94rem;max-width:90vw;
  display:flex;align-items:center;gap:10px;
  animation:toastIn .4s var(--spring);
  border:1px solid rgba(220,189,128,.25);
}
.toast--good{background:linear-gradient(135deg,#3f9b6d,#2f7b54)}
.toast--bad{background:linear-gradient(135deg,#c2503f,#a13b2c)}
@keyframes toastIn{from{opacity:0;transform:translateY(-14px) scale(.96)}to{opacity:1;transform:none}}

/* ---------- spinner ---------- */
.spinner{width:22px;height:22px;border-radius:50%;border:2.5px solid rgba(255,255,255,.35);border-top-color:#fff;animation:spin .7s linear infinite}
.spinner--ink{border-color:rgba(42,32,23,.25);border-top-color:var(--ink)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- skeleton ---------- */
.skel{background:linear-gradient(90deg,rgba(176,136,74,.08),rgba(176,136,74,.18),rgba(176,136,74,.08));
  background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:10px}
@keyframes shimmer{to{background-position:-200% 0}}

/* ---------- reveal-on-load ---------- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- helpers ---------- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.shine{position:relative;overflow:hidden}
.shine::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);transform:translateX(-120%);animation:shine 4.5s ease-in-out infinite}
@keyframes shine{0%,55%{transform:translateX(-120%)}80%,100%{transform:translateX(120%)}}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}
