/* TheirGame orchestrator — bright PuppyParty brand. Shares the game palette
   (peach/blue/mint/yellow) + Baloo 2 / Nunito so the site and the games feel
   like one world. */
:root{
  --ink:#373047; --muted:#7f758c; --cream:#fff8ec;
  --peach:#ff8e72; --peach-dark:#ed6f57; --blue:#63aee9; --pink:#f28bb1;
  --mint:#75c9aa; --yellow:#ffd670; --field:#82ad36;
  --paper:#fffdf8; --line:#efe3d4;
  --shadow:0 18px 50px rgba(96,70,61,.16);
  --shadow-sm:0 6px 18px rgba(96,70,61,.12);
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%}
body{font-family:"Nunito",sans-serif;color:var(--ink);background:
  radial-gradient(1200px 600px at 80% -10%,#fff 0,#fff6e6 45%,#f7e9d4 100%) fixed;
  display:flex;flex-direction:column;min-height:100dvh}
a{color:var(--peach-dark);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:"Baloo 2",sans-serif;line-height:1.05;margin:0}
.eyebrow{margin:0;text-transform:uppercase;letter-spacing:.18em;font-size:11px;font-weight:800;color:var(--peach-dark)}
.page{flex:1;width:100%}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;border:0;border-radius:999px;
  font-weight:800;cursor:pointer;padding:12px 22px;font-size:15px;transition:.16s transform,.16s box-shadow;text-decoration:none;font-family:inherit}
.btn:hover{text-decoration:none}
.btn-primary{background:linear-gradient(#ff9c7f,#f27c62);color:#fff;box-shadow:0 5px 0 #d9634d,0 9px 18px #e9755d43}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 7px 0 #d9634d,0 11px 21px #e9755d43}
.btn-primary:active{transform:translateY(3px);box-shadow:0 2px 0 #d9634d}
.btn-ghost{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{transform:translateY(-2px)}
.btn-blue{background:linear-gradient(#74b6ec,#4f9bdc);color:#fff;box-shadow:0 5px 0 #3f86c4,0 9px 18px #63aee943}
.btn-text{background:none;color:var(--muted);box-shadow:none;padding:12px 10px}
.btn-text:hover{color:var(--ink)}
.btn-block{width:100%;justify-content:center}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none}

/* Nav */
.nav{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:18px;
  padding:14px clamp(16px,4vw,40px);background:#fffdf8e8;backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-brand{display:flex;align-items:center;gap:9px;font-family:"Baloo 2";font-weight:800;font-size:22px;color:var(--ink)}
.nav-brand:hover{text-decoration:none}
.nav-word{background:linear-gradient(90deg,var(--peach),var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent}
.nav-paw{width:30px;height:27px;position:relative;transform:rotate(-6deg);flex:none}
.nav-paw i,.nav-paw b{position:absolute;background:var(--peach);border-radius:50%}
.nav-paw i:nth-child(1){width:8px;height:11px;left:1px;top:6px;transform:rotate(-25deg)}
.nav-paw i:nth-child(2){width:9px;height:12px;left:8px;top:0}
.nav-paw i:nth-child(3){width:9px;height:12px;right:7px;top:0}
.nav-paw i:nth-child(4){width:8px;height:11px;right:0;top:7px;transform:rotate(25deg)}
.nav-paw b{width:21px;height:17px;left:5px;bottom:0}
.nav-links{display:flex;gap:20px;margin-left:8px}
.nav-links a{color:var(--muted);font-weight:700;font-size:14px}
.nav-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.nav-logout{margin:0}
@media(max-width:760px){.nav-links{display:none}.nav-actions .btn-ghost{display:none}}

/* Footer */
.footer{margin-top:40px;border-top:1px solid var(--line);background:#fffdf8aa}
.footer-inner{max-width:1100px;margin:0 auto;padding:26px 20px;text-align:center;color:var(--muted)}
.footer-paw{font-size:22px}
.footer p{margin:6px 0;font-weight:700}
.footer-fine{font-size:12px;opacity:.8}

/* Flash */
.flash{border-radius:14px;padding:11px 16px;font-weight:700;font-size:14px;margin:0 0 14px}
.flash-success{background:#e7f6ee;color:#2f7d5b}
.flash-error{background:#fdeceb;color:#c4453c}
.flash-info{background:#eaf3fb;color:#3a73a4}

/* Generic containers */
.wrap{max-width:1100px;margin:0 auto;padding:0 clamp(16px,4vw,40px)}
.section{padding:clamp(48px,8vw,90px) 0}
.section h2{font-size:clamp(28px,4vw,40px);text-align:center}
.section-sub{text-align:center;color:var(--muted);font-weight:700;max-width:560px;margin:10px auto 0}

/* Hero */
.hero{position:relative;overflow:hidden;text-align:center;padding:clamp(40px,7vw,84px) 20px 30px}
.hero:before,.hero:after{content:"";position:absolute;border-radius:50%;filter:blur(2px);z-index:0}
.hero:before{width:460px;height:460px;left:-220px;top:20%;background:#dff1d4aa}
.hero:after{width:420px;height:420px;right:-200px;top:-10%;background:#dfeff7aa}
.hero-inner{position:relative;z-index:1;max-width:760px;margin:0 auto}
.hero-paw{font-size:46px;animation:bob 3s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-9px) rotate(4deg)}}
.hero h1{font-size:clamp(42px,7vw,76px);text-transform:uppercase;letter-spacing:.02em;margin:10px 0 6px;color:var(--peach);text-shadow:0 4px 0 #fff,0 7px 0 #e7b48b}
.hero h1 span{display:block;color:var(--blue);text-shadow:0 4px 0 #fff,0 7px 0 #a9cde2}
.hero p.lead{font-size:clamp(16px,2.4vw,20px);color:var(--muted);font-weight:700;margin:14px auto 24px;max-width:540px}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* Cards / grids */
.cards{display:grid;gap:18px;margin-top:34px}
.cards.cols-3{grid-template-columns:repeat(3,1fr)}
.cards.cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:820px){.cards.cols-3,.cards.cols-2{grid-template-columns:1fr}}
.card{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:24px;box-shadow:var(--shadow-sm)}
.card h3{font-size:20px;margin-bottom:6px}
.card .step-num{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:50%;
  background:linear-gradient(var(--blue),#4f9bdc);color:#fff;font-family:"Baloo 2";font-weight:800;margin-bottom:12px}

/* Pricing */
.price-card{max-width:380px;margin:34px auto 0;text-align:center;background:var(--paper);
  border:2px solid var(--peach);border-radius:26px;padding:34px;box-shadow:var(--shadow)}
.price-amount{font-family:"Baloo 2";font-weight:800;font-size:58px;color:var(--peach);line-height:1}
.price-amount small{font-size:18px;color:var(--muted)}
.price-card ul{list-style:none;padding:0;margin:18px 0;text-align:left}
.price-card li{padding:7px 0 7px 30px;position:relative;font-weight:700}
.price-card li:before{content:"🐾";position:absolute;left:0}

/* Game gallery cards */
.game-card{display:block;background:var(--paper);border:1px solid var(--line);border-radius:20px;
  overflow:hidden;box-shadow:var(--shadow-sm);transition:.18s transform}
.game-card:hover{transform:translateY(-4px);text-decoration:none}
.game-card-banner{height:88px;display:grid;place-items:center;font-size:34px}
.game-card-body{padding:14px 16px}
.game-card-body h3{font-size:18px}
.game-card-body p{margin:4px 0 0;color:var(--muted);font-weight:700;font-size:13px}
.game-card-meta{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}
.tag{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:3px 9px;background:#f3ede6;color:var(--muted)}
.tag.live{background:#e7f6ee;color:#2f7d5b}

/* Leaderboard table */
.lb-table{width:100%;border-collapse:collapse;background:var(--paper);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}
.lb-table th,.lb-table td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}
.lb-table th{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);background:#fbf5ec}
.lb-table td.rank{font-family:"Baloo 2";font-weight:800;color:var(--peach-dark);width:46px}
.lb-table td.score{font-family:"Baloo 2";font-weight:800;text-align:right;color:var(--ink)}
.lb-empty{text-align:center;color:var(--muted);padding:30px;font-weight:700}

/* Auth */
.auth-screen{display:grid;place-items:center;padding:clamp(30px,8vw,80px) 20px}
.auth-card{width:min(440px,100%);background:var(--paper);border:1px solid #fff;border-radius:28px;
  box-shadow:var(--shadow);padding:38px 34px;text-align:center}
.auth-paw{font-size:42px}
.auth-title{font-size:30px;margin:6px 0 8px}
.auth-sub{color:var(--muted);font-weight:700;margin:0 0 18px}
.auth-form{text-align:left;margin-top:8px}
.auth-form label{display:block;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 6px}
.auth-form input{width:100%;border:2px solid var(--line);border-radius:14px;padding:13px 15px;font:700 16px Nunito;background:#fffaf5;color:var(--ink);outline:none;margin-bottom:14px}
.auth-form input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #63aee91f}
.code-input{letter-spacing:.5em;text-align:center;font-family:"Baloo 2";font-size:26px!important}
.auth-fine{margin-top:16px;font-size:13px;color:var(--muted)}
.auth-dev{margin-top:14px;font-size:13px;background:#fff6e0;border:1px dashed #e7c878;border-radius:12px;padding:9px 12px;color:#8a6d2a}
.auth-dev code{background:#fff;border-radius:6px;padding:1px 7px;font-weight:800}

/* Dashboard */
.dash-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:8px}
.dash-head h1{font-size:34px}
.empty-state{text-align:center;padding:60px 20px;background:var(--paper);border:2px dashed var(--line);border-radius:24px;margin-top:20px}
.empty-state .big{font-size:46px}
.game-row{display:flex;align-items:center;gap:16px;background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:16px 18px;margin-top:12px;box-shadow:var(--shadow-sm)}
.game-row .swatch{width:46px;height:46px;border-radius:12px;flex:none}
.game-row .grow{flex:1;min-width:0}
.game-row h3{font-size:18px}
.game-row .sub{color:var(--muted);font-weight:700;font-size:13px;margin-top:2px}
.game-row .actions{display:flex;gap:8px;flex-wrap:wrap}
.status-pill{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:3px 10px}
.status-draft{background:#f3ede6;color:var(--muted)}
.status-paid{background:#fff2dd;color:#a9772a}
.status-deploying{background:#eaf3fb;color:#3a73a4}
.status-live{background:#e7f6ee;color:#2f7d5b}
.status-failed{background:#fdeceb;color:#c4453c}

/* ── Studio (buyer-friendly redesign) ───────────────────────────────── */
.studio-body{background:radial-gradient(1200px 600px at 80% -10%,#fff 0,#fff6e6 45%,#f7e9d4 100%) fixed}
.studio{display:grid;grid-template-columns:1fr 400px;grid-template-rows:auto auto 1fr;gap:22px 28px;
  max-width:1180px;margin:0 auto;padding:20px clamp(14px,3vw,32px) 90px;align-items:start}
.studio-head{grid-column:1/-1;display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap}
.studio-head h1{font-size:30px}
.studio-form{grid-column:1;grid-row:2/4;min-width:0}
.studio-preview{grid-column:2;grid-row:2;position:sticky;top:78px}
.studio-preview .frame-wrap{border:6px solid #fff;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);background:#b9d99b;aspect-ratio:3/2}
.studio-preview iframe{width:100%;height:100%;border:0;display:block}
.pv-cap{text-align:center;color:var(--muted);font-weight:800;font-size:12px;margin:10px 0 0}
.opt{color:var(--muted);font-weight:700;font-size:.8em}

.panel{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:18px 20px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.panel h2{font-size:19px;margin-bottom:3px}
.panel .hint{color:var(--muted);font-weight:700;font-size:13px;margin:0 0 14px}
.field{margin-bottom:13px}
.field label{display:block;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 6px}
.field input{width:100%;border:2px solid var(--line);border-radius:12px;padding:12px 13px;font:700 15px Nunito;background:#fffaf5;color:var(--ink);outline:none}
.field input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #63aee91f}

/* palettes */
.palette-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.palette{border:2px solid var(--line);background:#fff;border-radius:14px;padding:9px 6px 8px;cursor:pointer;text-align:center;transition:.15s}
.palette:hover{transform:translateY(-2px)}
.palette.on{border-color:var(--blue);background:#f3fbff;box-shadow:0 5px 14px #63aee926}
.palette-swatches{display:flex;height:26px;border-radius:7px;overflow:hidden;margin-bottom:6px}
.palette-swatches i{flex:1}
.custom-swatch{display:grid;place-items:center;font-size:18px;background:#f6efe6}
.palette b{font-size:12px;font-weight:800}
.custom-colors{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap}
.custom-colors.hidden{display:none}
.swatch-field{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:7px 11px}
.swatch-field input[type=color]{width:34px;height:34px;border:0;border-radius:8px;background:none;cursor:pointer;padding:0}
.swatch-field span{font-size:12px;font-weight:800;color:var(--muted)}

/* picture slots */
.pslot{display:flex;gap:13px;align-items:flex-start;border:1px solid var(--line);border-radius:15px;padding:12px;margin-bottom:11px;background:#fffdf8;position:relative}
.pslot.busy{opacity:.55;pointer-events:none}
.pslot.busy:after{content:"…";position:absolute;inset:0;display:grid;place-items:center;font:800 26px Nunito;color:var(--peach)}
.pslot-thumb{width:64px;height:64px;border-radius:14px;flex:none;background:#f3ede6 center/contain no-repeat;border:1px solid var(--line)}
.pslot-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}
.pslot-name{width:100%;border:2px solid var(--line);border-radius:10px;padding:9px 11px;font:700 14px Nunito;background:#fffaf5;outline:none}
.pslot-name:focus{border-color:var(--blue)}
.pslot-rarity{border:2px solid var(--line);border-radius:10px;padding:8px 10px;font:800 13px Nunito;background:#fff;color:var(--ink);cursor:pointer;align-self:flex-start}
.pslot-actions{display:flex;gap:7px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:4px;border:1.5px solid var(--line);background:#fff;border-radius:999px;padding:6px 12px;font:800 12px Nunito;color:var(--ink);cursor:pointer}
.chip:hover{border-color:var(--blue);color:var(--blue)}
.chip input[type=file]{display:none}
.pslot-reset{padding:6px 10px}
.pslot-crop{font-size:12px;font-weight:700;color:#8a6d2a;background:#fff6e0;border:1px dashed #e7c878;border-radius:10px;padding:6px 10px}
.link{border:0;background:none;color:var(--peach-dark);font-weight:800;cursor:pointer;padding:0;font-size:12px;text-decoration:underline}

/* modes / toggles */
.mode-checks{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.mode-check{display:flex;align-items:center;gap:8px;border:2px solid var(--line);border-radius:12px;padding:10px 12px;cursor:pointer;font-weight:800;background:#fff;font-size:14px}
.mode-check input{accent-color:var(--peach);width:17px;height:17px}
.mode-check.on{border-color:var(--blue);background:#f5fbff}
.toggle{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--ink)}
.toggle input{width:18px;height:18px;accent-color:var(--peach)}

/* sticky actions */
.studio-actions{grid-column:1/-1;grid-row:4;position:sticky;bottom:0;display:flex;gap:12px;justify-content:flex-end;
  background:linear-gradient(transparent,#f7e9d4 45%);padding:16px 0 8px;flex-wrap:wrap;z-index:6}

/* sample modal */
.sample-modal{position:fixed;inset:0;z-index:40;background:#3d354d8c;display:grid;place-items:center;padding:18px;backdrop-filter:blur(6px)}
.sample-modal[hidden]{display:none}
.sample-card{width:min(440px,100%);background:var(--paper);border-radius:22px;box-shadow:var(--shadow);padding:18px}
.sample-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.sample-head b{font-family:"Baloo 2";font-size:18px}
.sample-close{border:0;background:#f3ede6;border-radius:50%;width:30px;height:30px;font-weight:900;cursor:pointer}
.sample-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.sample-tile{border:2px solid var(--line);background:#fff;border-radius:12px;padding:5px;cursor:pointer;aspect-ratio:1;display:grid;place-items:center}
.sample-tile:hover{border-color:var(--blue);transform:translateY(-2px)}
.sample-tile img{width:100%;height:auto}

/* MOBILE: preview prominent + sticky at top, single column */
@media(max-width:900px){
  .studio{grid-template-columns:1fr;padding-bottom:80px}
  .studio-preview{grid-column:1;grid-row:2;position:sticky;top:56px;z-index:8;
    background:#f7e9d4;padding:8px 0;margin:0 -2px}
  .studio-preview .frame-wrap{max-height:34vh;aspect-ratio:3/2;margin:0 auto;max-width:calc(34vh * 1.5)}
  .pv-cap{margin-top:5px}
  .studio-form{grid-column:1;grid-row:3}
  .palette-grid{grid-template-columns:repeat(3,1fr)}
  .sample-grid{grid-template-columns:repeat(5,1fr)}
}
@media(max-width:560px){
  .studio-head h1{font-size:24px}
  .mode-checks{grid-template-columns:1fr}
  .palette-grid{grid-template-columns:repeat(2,1fr)}
}
