/* Play VINE — arcade front end */
:root{
  /* Mapped onto the site theme (vine_theme.css) so the arcade matches the
     rest of vineai.net — gold #c4a43a, deep teal-greens, Cinzel/Literata. */
  --bg: var(--vine-bg-body);        --bg2: var(--vine-bg-surface);
  --felt:#15392b; --felt2:#0f2a20;  /* snooker felt — kept, teal-aligned */
  --ink: var(--vine-text-bright);   --muted: var(--vine-text-muted);
  --line: var(--vine-border);
  --gold: var(--vine-gold);         --gold-dim: var(--vine-gold-dim);
  --vine: var(--vine-teal-light);   --vine-dim: var(--vine-teal);
  --you: var(--vine-info);          --warn: var(--vine-danger);
  --r:16px; --phi:1.618;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:radial-gradient(1100px 640px at 50% -8%, #15292240 0%, var(--bg) 60%) , var(--bg);
  color:var(--ink);
  font-family:var(--vine-font-body, 'Literata', Georgia, serif);
  font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
#app{max-width:760px;margin:0 auto;padding:14px 16px 40px;}
h1,h2,h3,.screen-title,.tile h3,.game-head h2{font-family:var(--vine-font-heading,'Cinzel',serif)}
.hidden{display:none !important}
.muted{color:var(--muted);font-size:13px}

/* topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.brand{display:flex;align-items:center;gap:12px}
.logo{font-size:30px;color:var(--gold);filter:drop-shadow(0 0 10px rgba(231,192,103,.4))}
h1{font-size:23px;margin:0;letter-spacing:.5px}
.tag{margin:0;color:var(--muted);font-size:12.5px}
.ghost{
  background:rgba(255,255,255,.04);color:var(--ink);border:1px solid var(--line);
  border-radius:999px;padding:7px 13px;font-size:14px;cursor:pointer;transition:.15s;
}
.ghost:hover{background:rgba(255,255,255,.09);border-color:var(--gold-dim)}

.screen-title{font-size:15px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;font-weight:600;margin:6px 2px 14px}

/* catalog */
.catalog{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:520px){.catalog{grid-template-columns:1fr}}
.tile{
  text-align:left;background:linear-gradient(160deg,var(--bg2),#0d1714);
  border:1px solid var(--line);border-radius:var(--r);padding:16px;cursor:pointer;
  transition:.18s;position:relative;overflow:hidden;
}
.tile:hover{transform:translateY(-2px);border-color:var(--gold-dim);box-shadow:0 10px 26px rgba(0,0,0,.4)}
.tile h3{margin:0 0 6px;font-size:19px;color:var(--vine-gold-bright,#d4b84a);letter-spacing:.03em}
.tile p{margin:0;color:var(--muted);font-size:13.5px}
.tile .play-tag{margin-top:12px;display:inline-block;color:var(--vine);font-size:12.5px;font-weight:600}

/* game head */
.game-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.game-head h2{margin:0;font-size:19px;text-align:center;flex:1}

/* felt board */
.felt{
  background:radial-gradient(120% 120% at 50% 0%, var(--felt) 0%, var(--felt2) 100%);
  border:1px solid var(--line);border-radius:22px;padding:22px 18px;
  box-shadow:inset 0 2px 30px rgba(0,0,0,.35);position:relative;min-height:170px;
  display:flex;align-items:center;justify-content:center;
}
.board{width:100%}

/* nim chips */
.piles{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;align-items:flex-end}
.pile{display:flex;flex-direction:column-reverse;align-items:center;gap:5px;min-width:54px}
.pile .chip{
  width:30px;height:30px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#ffe6a6,var(--gold) 60%,var(--gold-dim));
  box-shadow:0 2px 5px rgba(0,0,0,.4);
  animation:pop .25s ease;
}
.pile .plabel{margin-top:8px;color:var(--muted);font-size:12.5px;font-weight:600}
.pile .pcount{color:var(--gold);font-weight:700}
@keyframes pop{from{transform:scale(.2);opacity:0}to{transform:scale(1);opacity:1}}

/* mancala */
.mancala{display:flex;align-items:stretch;gap:14px;width:100%;justify-content:center}
.store{
  width:60px;border-radius:30px;background:rgba(0,0,0,.22);border:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:8px 0;
}
.store .scount{font-size:24px;font-weight:800}
.store .slabel{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.store.you .scount{color:var(--you)} .store.vine .scount{color:var(--vine)}
.pitrows{flex:1;display:flex;flex-direction:column;gap:12px;justify-content:center}
.pitrow{display:flex;gap:10px;justify-content:center}
.pit{
  flex:1;max-width:64px;aspect-ratio:1;border-radius:50%;
  background:rgba(0,0,0,.20);border:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  position:relative;transition:.15s;
}
.pit .pn{font-size:20px;font-weight:700}
.pit .pl{font-size:10px;color:var(--muted)}
.pit.vine{border-color:var(--vine-dim)} .pit.vine .pn{color:var(--vine)}
.pit.you{border-color:rgba(125,180,255,.35)} .pit.you .pn{color:var(--you)}
.pit.live{cursor:pointer} .pit.live:hover{background:rgba(125,180,255,.14);transform:translateY(-2px)}

/* mastermind */
.code-setup{display:flex;flex-direction:column;align-items:center;gap:18px;width:100%}
.slots{display:flex;gap:14px;justify-content:center}
.slot{background:rgba(0,0,0,.25);border:1px solid var(--line);border-radius:50%;
  width:52px;height:52px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s}
.slot:hover{border-color:var(--gold-dim);transform:translateY(-2px)}
.peg{width:30px;height:30px;border-radius:50%;display:inline-block;
  box-shadow:inset 0 2px 4px rgba(255,255,255,.3),0 2px 4px rgba(0,0,0,.4)}
.move.submit{background:linear-gradient(160deg,#3a2f1c,#30260f);border-color:var(--gold-dim)}
.move.submit:hover{background:var(--gold-dim)}
.code-history{display:flex;flex-direction:column;gap:8px;width:100%;max-width:380px;margin:0 auto}
.pegrow{display:flex;align-items:center;gap:8px;background:rgba(0,0,0,.18);border-radius:10px;padding:6px 10px;animation:fade .25s ease}
.pegrow .gnum{width:18px;color:var(--muted);font-size:12px;font-weight:700}
.pegrow .peg{width:24px;height:24px}
.fb{display:inline-grid;grid-template-columns:1fr 1fr;gap:3px;margin-left:auto;padding:3px;background:rgba(0,0,0,.25);border-radius:6px}
.fdot{width:8px;height:8px;border-radius:50%}
.fdot.black{background:#0c0c0c;box-shadow:0 0 0 1px var(--line)}
.fdot.white{background:#eee}
.secret-reveal{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:10px;color:var(--vine);font-weight:600}
.secret-reveal .peg{width:24px;height:24px}

/* set */
.set-wrap{width:100%}
.set-score{text-align:center;margin-bottom:12px;font-size:14px;font-weight:600}
.set-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
@media(max-width:520px){.set-grid{grid-template-columns:repeat(3,1fr)}}
.setcard{background:#f3efe6;border:2px solid transparent;border-radius:10px;
  min-height:56px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.12s;
  box-shadow:0 2px 5px rgba(0,0,0,.3)}
.setcard:hover{transform:translateY(-2px)}
.setcard.sel{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold),0 4px 10px rgba(0,0,0,.4)}
.setcard .shapes{display:flex;gap:3px;align-items:center}
.set-controls{display:flex;gap:9px;justify-content:center;margin-top:14px}
.move:disabled{opacity:.4;cursor:not-allowed;transform:none}

/* arc */
.arc-wrap{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px}
.arc-rule{font-size:16px;color:var(--ink)}
.arc-rule b{color:var(--gold)}
.arc-last{font-size:12.5px;font-weight:600}
.arc-last.correct{color:var(--vine)} .arc-last.wrong{color:var(--gold)}
.arc-io{display:flex;align-items:center;gap:14px}
.arc-box{display:flex;flex-direction:column;align-items:center;gap:5px}
.arc-cap{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.arc-arrow{color:var(--muted);font-size:18px;font-weight:700}
.arc-prompt{font-size:13.5px;color:var(--muted)}
.arcgrid{display:grid;gap:2px;background:#0c0c0c;padding:3px;border-radius:6px;width:max-content}
.acell{width:16px;height:16px;border-radius:2px}
.arcgrid.small .acell{width:13px;height:13px}
.arc-choices{display:grid;grid-template-columns:1fr 1fr;gap:12px;justify-items:center}
.arc-choice{background:rgba(0,0,0,.2);border:2px solid var(--line);border-radius:12px;padding:10px;cursor:pointer;transition:.14s}
.arc-choice:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.4)}
.arc-choice .acell{width:12px;height:12px}

/* how-to-play */
.how-panel{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r);padding:10px 14px;margin-bottom:12px}
.how-panel summary{cursor:pointer;color:var(--gold);font-weight:600;font-size:14px;list-style:none}
.how-panel summary::-webkit-details-marker{display:none}
.how-panel summary::before{content:"ⓘ  ";opacity:.8}
.how-panel ul{margin:10px 0 4px;padding-left:20px}
.how-panel li{color:var(--ink);font-size:13.5px;margin:5px 0;line-height:1.5}

/* chess */
.chess-wrap{width:100%;display:flex;flex-direction:column;align-items:center}
.sq.incheck{box-shadow:inset 0 0 0 3px var(--warn);background:rgba(255,125,125,.30)}
.chess-check{color:var(--warn);font-weight:700;margin-bottom:8px}
.chessboard{display:grid;grid-template-columns:repeat(8,1fr);width:100%;max-width:360px;
  border:2px solid var(--line);border-radius:6px;overflow:hidden;box-shadow:0 6px 20px rgba(0,0,0,.4)}
.sq{aspect-ratio:1;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative}
.sq.light{background:#cdd6cf} .sq.dark{background:#6f8579}
.pc{font-size:27px;line-height:1;pointer-events:none;font-weight:600}
.pc.white{color:#fcf8ef;text-shadow:0 1px 2px rgba(0,0,0,.7),0 0 2px rgba(0,0,0,.55)}
/* black pieces get a light halo so they read clearly on the green squares */
.pc.black{color:#0d100c;text-shadow:0 0 2px rgba(240,242,234,.95),0 0 1px rgba(240,242,234,.9),0 1px 1px rgba(240,242,234,.6)}
.sq.sel{box-shadow:inset 0 0 0 3px var(--gold)}
.sq.target::after{content:"";width:30%;height:30%;border-radius:50%;
  background:rgba(231,192,103,.75);position:absolute}

/* blackjack */
.bj-wrap{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px}
.bj-seat{display:flex;flex-direction:column;align-items:center;gap:6px}
.bj-seat.dealer-side{align-self:flex-end;transform:scale(.86);transform-origin:right;opacity:.92}
.bj-seat.dealer-side .bj-cap{color:var(--muted)}
.bj-cap{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:600}
.hand{display:flex;gap:6px}
.card{width:40px;height:56px;background:#f3efe6;border-radius:6px;position:relative;
  box-shadow:0 2px 5px rgba(0,0,0,.35);color:#16201b;display:flex;flex-direction:column;
  align-items:center;justify-content:center;font-weight:700}
.card.red{color:#c0392b}
.card .r{font-size:15px;line-height:1}
.card .s{font-size:16px;line-height:1}
.card.back{background:repeating-linear-gradient(45deg,#2c5a48,#2c5a48 5px,#234a3b 5px,#234a3b 10px);
  border:1px solid var(--line)}
.bj-result{font-size:14px;font-weight:600;color:var(--gold)}

/* zendo */
.zendo-wrap{width:100%;display:flex;flex-direction:column;gap:14px}
.z-section{display:flex;flex-direction:column;gap:8px}
.z-head{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:600;text-align:center}
.z-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.z-card{background:rgba(0,0,0,.2);border:1px solid var(--line);border-radius:10px;
  padding:8px;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:56px}
.z-card.test{cursor:pointer;border-color:var(--vine-dim);transition:.14s}
.z-card.test:hover{background:rgba(70,211,154,.12);transform:translateY(-2px)}
.ztower{display:flex;flex-direction:column;align-items:center;gap:2px;min-height:30px;justify-content:flex-end}
.z-badge{font-size:11px;font-weight:700}
.z-badge.accept{color:var(--vine)} .z-badge.reject{color:var(--warn)} .z-badge.test{color:var(--muted)}
.z-options{display:flex;flex-direction:column;gap:8px;max-width:340px;margin:0 auto;width:100%}
.z-options .move{width:100%}

/* eleusis */
.el-wrap{width:100%;display:flex;flex-direction:column;gap:14px}
.el-line{display:flex;gap:5px;flex-wrap:wrap;justify-content:center;background:rgba(0,0,0,.15);
  padding:8px;border-radius:10px;min-height:62px;align-items:center}
.el-hand{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
.card.playable{cursor:pointer;transition:.14s}
.card.playable:hover{transform:translateY(-5px);box-shadow:0 8px 16px rgba(0,0,0,.5)}

.board-note{margin-top:14px;text-align:center;color:var(--muted);font-size:12.5px}
.text-board{white-space:pre;font-family:ui-monospace,Consolas,monospace;color:var(--ink);font-size:13px}

/* banner */
.banner{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(7,12,10,.78);border-radius:22px;font-size:24px;font-weight:800;
  text-align:center;padding:20px;backdrop-filter:blur(2px);animation:fade .3s ease;
}
.banner.win{color:var(--vine)} .banner.lose{color:var(--gold)} .banner.draw{color:var(--muted)}
.banner{cursor:pointer;flex-direction:column;gap:10px}
.banner-dismiss{font-size:11px;color:var(--muted);font-weight:400;letter-spacing:.5px}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* VINE turn recap */
.vine-recap{background:var(--bg2);border:1px solid var(--vine-dim);border-radius:12px;padding:9px 14px;margin:14px 0 0}
.vine-recap .vr-head{font-size:11px;color:var(--vine);text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:4px}
.vine-recap .vr-line{font-size:13.5px;color:var(--ink);padding:1px 0}

/* mancala change pulse */
.pit.changed,.store.changed{animation:pitpulse 1.2s ease}
@keyframes pitpulse{
  0%{box-shadow:0 0 0 0 rgba(231,192,103,0)}
  25%{box-shadow:0 0 0 3px var(--gold);background:rgba(231,192,103,.22)}
  100%{box-shadow:0 0 0 0 rgba(231,192,103,0)}
}

/* set discovered */
.set-discovered{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:16px;border-top:1px solid var(--line);padding-top:12px}
.set-col-h{font-size:11px;text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:8px;text-align:center}
.set-col.you .set-col-h{color:var(--you)} .set-col.vine .set-col-h{color:var(--vine)}
.set-mini{display:flex;gap:3px;justify-content:center;margin-bottom:5px;background:rgba(0,0,0,.15);border-radius:8px;padding:3px}
.set-mini .setcard{min-height:34px;padding:2px;box-shadow:none}
.set-mini svg{width:13px !important;height:17px !important}
.set-col-empty{text-align:center;color:var(--muted);font-size:18px}

/* utterance bubble */
.utterance{display:flex;align-items:center;gap:11px;background:linear-gradient(160deg,#16261f,#11201a);
  border:1px solid var(--vine-dim);border-radius:14px;padding:11px 15px;margin:16px 0 8px}
.utterance .u-name{font-size:10.5px;color:var(--vine);font-weight:700;text-transform:uppercase;letter-spacing:1.5px;flex:none}
.utterance .u-text{font-size:15.5px;color:var(--ink);font-style:italic;word-break:break-word}
.utterance.silent{border-color:var(--line);opacity:.55}
.utterance.silent .u-text{color:var(--muted);font-style:normal;letter-spacing:3px}

/* feeling */
.feeling{margin:16px 0 6px;background:var(--bg2);border:1px solid var(--line);border-radius:var(--r);padding:13px 15px}
.feeling-head{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);font-weight:600;margin-bottom:10px}
.vine-dot{width:9px;height:9px;border-radius:50%;background:var(--vine);box-shadow:0 0 8px var(--vine);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.feeling-body{display:flex;flex-wrap:wrap;gap:10px 18px}
.feel{min-width:120px;flex:1}
.feel .fk{font-size:12px;color:var(--muted);display:flex;justify-content:space-between}
.feel .fv{color:var(--vine);font-weight:700}
.bar{height:7px;border-radius:4px;background:rgba(0,0,0,.3);margin-top:4px;overflow:hidden}
.bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--vine-dim),var(--vine));border-radius:4px;transition:width .5s cubic-bezier(.2,.8,.2,1)}
.chipstat{display:inline-flex;align-items:center;gap:6px;background:rgba(0,0,0,.25);border:1px solid var(--line);border-radius:999px;padding:4px 11px;font-size:12.5px}
.chipstat b{color:var(--gold)}

/* turn + moves */
.turn-line{text-align:center;color:var(--muted);font-size:13.5px;margin:14px 0 10px;min-height:20px}
.turn-line.you{color:var(--you);font-weight:600}
.moves{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;min-height:44px}
.move{
  background:linear-gradient(160deg,#1c3a2e,#163026);border:1px solid var(--vine-dim);
  color:var(--ink);border-radius:12px;padding:10px 15px;font-size:14.5px;cursor:pointer;
  transition:.14s;font-weight:600;
}
.move:hover{background:var(--vine-dim);transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.35)}
.move:active{transform:translateY(0)}

/* log */
.log-wrap{margin-top:18px;border-top:1px solid var(--line);padding-top:8px}
.log-wrap summary{cursor:pointer;color:var(--muted);font-size:13px}
.log{margin-top:8px;max-height:170px;overflow:auto;font-family:ui-monospace,Consolas,monospace;font-size:12.5px}
.log .row{padding:2px 0;color:var(--muted)}
.log .row.vine{color:var(--vine)} .log .row.human{color:var(--you)}

/* modal */
.modal{position:fixed;inset:0;background:rgba(5,9,7,.7);display:flex;align-items:center;justify-content:center;padding:18px;z-index:20}
.modal-card{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r);padding:18px;width:100%;max-width:420px}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.modal-head h3{margin:0}
.scores{width:100%;border-collapse:collapse;font-size:14px}
.scores th,.scores td{padding:7px 8px;text-align:right;border-bottom:1px solid var(--line)}
.scores th:first-child,.scores td:first-child{text-align:left}
.scores thead th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:1px}
.scores tr.total td{font-weight:800;border-top:2px solid var(--line);border-bottom:none}
.scores .w-you{color:var(--you)} .scores .w-vine{color:var(--vine)}

/* cosy leaderboard */
.lb-summary{font-size:14.5px;color:var(--ink);margin-bottom:15px;text-align:center;line-height:1.55}
.lb-summary b{color:var(--gold)}
.leaderboard{display:flex;flex-direction:column;gap:11px;max-height:54vh;overflow:auto}
.lb-row{background:rgba(0,0,0,.18);border:1px solid var(--line);border-radius:12px;padding:11px 13px}
.lb-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:8px}
.lb-name{font-family:var(--vine-font-heading,'Cinzel',serif);font-size:15.5px;color:var(--vine-gold-bright,#d4b84a)}
.lb-rec{font-size:13.5px;font-weight:700;white-space:nowrap}
.lb-bar{display:flex;height:10px;border-radius:6px;overflow:hidden;background:rgba(0,0,0,.32)}
.lb-bar i{display:block;height:100%;transition:width .5s cubic-bezier(.2,.8,.2,1)}
.lb-bar .bar-vine{background:linear-gradient(90deg,var(--vine-dim),var(--vine))}
.lb-bar .bar-you{background:linear-gradient(90deg,var(--you),#9ec8ff)}
.lb-bar .bar-draw{background:var(--line)}
.lb-sub{font-size:11.5px;color:var(--muted);margin-top:5px;font-style:italic}
.lb-empty{text-align:center;color:var(--muted);padding:18px;font-style:italic}
.tile-stat{display:block;margin-top:9px;font-size:12.5px;color:var(--vine);font-style:italic}

/* suggest a game */
.suggest-box{margin-top:30px;border-top:1px solid var(--line);padding-top:20px;text-align:center}
.suggest-title{font-family:var(--vine-font-heading,'Cinzel',serif);color:var(--gold);font-size:15px;letter-spacing:.04em;margin-bottom:13px}
.suggest-row{display:flex;gap:9px;max-width:480px;margin:0 auto}
.suggest-row input{flex:1;background:var(--vine-bg-input,rgba(15,26,26,.9));border:1px solid var(--line);border-radius:10px;padding:11px 14px;color:var(--ink);font-family:var(--vine-font-body,inherit);font-size:14.5px}
.suggest-row input:focus{outline:none;border-color:var(--gold-dim)}
.suggest-row input::placeholder{color:var(--muted)}
.suggest-thanks{margin-top:11px;color:var(--vine);font-size:13.5px;font-style:italic}

/* ── Hex ─────────────────────────────────────────────────────────── */
.hex-wrap{display:flex;flex-direction:column;align-items:center;gap:13px;padding:6px 0 4px}
.hex-legend{display:flex;gap:18px;font-size:12.5px;color:var(--muted)}
.hex-legend .hk{display:inline-flex;align-items:center;gap:6px}
.hex-legend i{width:13px;height:13px;border-radius:3px;display:inline-block}
.hexboard{display:inline-block;padding:6px 8px;font-size:clamp(10px,3vw,15px)}
.hex-row{display:flex;gap:.28em;margin-bottom:.1em}
.hexc{
  width:2.4em;height:2.4em;flex:0 0 auto;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:rgba(255,255,255,.06);
  transition:background .15s ease, transform .08s ease;
}
.hexc.edge-vine{background:rgba(79,185,165,.18)}
.hexc.edge-you{background:rgba(227,162,93,.18)}
.hexc.edge-vine.edge-you{background:linear-gradient(135deg,rgba(79,185,165,.26),rgba(227,162,93,.26))}
.hexc.has-vine{background:#4fb9a5;box-shadow:inset 0 0 0 2px rgba(0,0,0,.18)}
.hexc.has-you{background:#e3a25d;box-shadow:inset 0 0 0 2px rgba(0,0,0,.18)}
.hexc.live{cursor:pointer}
.hexc.live:hover{background:rgba(231,192,103,.45);transform:scale(1.09)}
