/* Tablica Reklamowa — tech-minimal + lime accent
   Font: Geist + Geist Mono (Vercel)
   Paleta: warm off-white / near-black / lime accent */

@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500&display=swap');

:root {
    --tabl-bg: #FAFAFA;
    --tabl-bg-dim: #F4F4F4;
    --tabl-canvas-bg: #FFFFFF;
    --tabl-ink: #0A0A0A;
    --tabl-ink-dim: #525252;
    --tabl-ink-mute: #A3A3A3;
    --tabl-line: #E5E5E5;
    --tabl-line-strong: #171717;
    --tabl-accent: #A3E635;
    --tabl-accent-deep: #65A30D;
    --tabl-accent-bg: #ECFCCB;
    --tabl-error: #EF4444;
    --tabl-error-bg: #FEF2F2;

    --tabl-font-sans: 'Geist', system-ui, sans-serif;
    --tabl-font-mono: 'Geist Mono', ui-monospace, 'JetBrains Mono', monospace;

    --tabl-shadow-sharp: 0 1px 0 var(--tabl-line-strong), 0 0 0 1px var(--tabl-line-strong);
    --tabl-shadow-soft: 0 1px 0 rgba(10,10,10,0.04), 0 0 0 1px var(--tabl-line);
}

/* ---- Page shell ---- */
.tabl-page { position: relative; width: 100%; height: calc(100vh - var(--header-height, 80px)); overflow: hidden; background: var(--tabl-bg); user-select: none; font-family: var(--tabl-font-sans); color: var(--tabl-ink); -webkit-font-smoothing: antialiased; }

/* ---- Stats overlay ---- */
.tabl-stats { position: absolute; top: 24px; left: 24px; z-index: 10; background: var(--tabl-canvas-bg); border: 1px solid var(--tabl-line-strong); padding: 14px 18px; font-family: var(--tabl-font-mono); font-size: 12px; line-height: 1.7; letter-spacing: 0.02em; box-shadow: 4px 4px 0 var(--tabl-line-strong); }
.tabl-stats-label { color: var(--tabl-ink-dim); font-size: 10px; text-transform: uppercase; letter-spacing: 0.12em; }
.tabl-stats-value { color: var(--tabl-ink); font-weight: 500; font-size: 14px; }
.tabl-stats-value strong { color: var(--tabl-accent-deep); }
.tabl-stats-divider { display: inline-block; width: 1px; height: 12px; background: var(--tabl-line); margin: 0 10px; vertical-align: middle; }

/* ---- Viewport / canvas ---- */
.tabl-viewport { width: 100%; height: 100%; overflow: hidden; cursor: default; position: relative; background: var(--tabl-canvas-bg); background-image: linear-gradient(var(--tabl-line) 1px, transparent 1px), linear-gradient(90deg, var(--tabl-line) 1px, transparent 1px); background-size: 40px 40px; background-position: -1px -1px; }
.tabl-page.is-buy .tabl-viewport { cursor: grab; }
.tabl-viewport.is-panning { cursor: grabbing; }
.tabl-viewport.is-buying { cursor: crosshair; }

.tabl-canvas { width: 1000px; height: 1000px; position: absolute; left: 0; top: 0; transform-origin: 0 0; background: var(--tabl-canvas-bg); background-image: linear-gradient(var(--tabl-line) 1px, transparent 1px), linear-gradient(90deg, var(--tabl-line) 1px, transparent 1px); background-size: 100px 100px; box-shadow: 0 0 0 1px var(--tabl-line-strong), 4px 4px 0 var(--tabl-line-strong); will-change: transform; }
.tabl-canvas.no-grid { background-image: none; }

/* ---- Reklamy ---- */
.tabl-ad { position: absolute; display: block; overflow: hidden; transition: outline 120ms ease, transform 120ms ease, z-index 0s; outline: 0 solid transparent; }
.tabl-ad img { display: block; width: 100%; height: 100%; object-fit: fill; }
.tabl-ad:hover { outline: 2px solid var(--tabl-accent); outline-offset: 0; z-index: 3; transform: scale(1.02); }
.tabl-ad:focus-visible { outline: 2px solid var(--tabl-accent); outline-offset: 2px; z-index: 3; }

/* ---- Selekcja w trybie buy ---- */
.tabl-selection { position: absolute; border: 1px solid var(--tabl-ink); background: rgba(163,230,53,0.18); pointer-events: none; z-index: 5; box-shadow: inset 0 0 0 1px rgba(163,230,53,0.6); }
.tabl-selection.is-invalid { border-color: var(--tabl-error); background: rgba(239,68,68,0.12); box-shadow: inset 0 0 0 1px rgba(239,68,68,0.6); }
.tabl-selection::before, .tabl-selection::after { content: ''; position: absolute; background: var(--tabl-accent); }
.tabl-selection.is-invalid::before, .tabl-selection.is-invalid::after { background: var(--tabl-error); }
.tabl-selection::before { left: -1px; top: -4px; width: 8px; height: 8px; }
.tabl-selection::after { right: -4px; bottom: -1px; width: 8px; height: 8px; }

/* ---- FAB (główny CTA) ---- */
.tabl-fab { position: absolute; bottom: 24px; right: 24px; z-index: 20; background: var(--tabl-accent); color: var(--tabl-ink); border: 1px solid var(--tabl-line-strong); padding: 14px 24px; font-family: var(--tabl-font-sans); font-size: 14px; font-weight: 600; letter-spacing: 0.01em; cursor: pointer; box-shadow: 4px 4px 0 var(--tabl-line-strong); transition: transform 120ms ease, box-shadow 120ms ease; display: inline-flex; align-items: center; gap: 8px; }
.tabl-fab:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--tabl-line-strong); }
.tabl-fab:active { transform: translate(0, 0); box-shadow: 2px 2px 0 var(--tabl-line-strong); }
.tabl-fab.is-active { background: var(--tabl-ink); color: var(--tabl-accent); }
.tabl-fab-dot { display: inline-block; width: 8px; height: 8px; background: var(--tabl-ink); border-radius: 50%; }
.tabl-fab.is-active .tabl-fab-dot { background: var(--tabl-accent); }

/* ---- Zoom controls (tylko w trybie buy) ---- */
.tabl-zoom-controls { display: none; position: absolute; bottom: 24px; left: 24px; z-index: 10; flex-direction: column; gap: 0; border: 1px solid var(--tabl-line-strong); background: var(--tabl-canvas-bg); box-shadow: 4px 4px 0 var(--tabl-line-strong); }
.tabl-page.is-buy .tabl-zoom-controls { display: flex; }
.tabl-zoom-controls button { width: 40px; height: 40px; border: 0; background: transparent; cursor: pointer; font-family: var(--tabl-font-mono); font-size: 16px; color: var(--tabl-ink); border-bottom: 1px solid var(--tabl-line); transition: background 120ms ease; }
.tabl-zoom-controls button:last-child { border-bottom: 0; }
.tabl-zoom-controls button:hover { background: var(--tabl-accent-bg); }
.tabl-zoom-controls button:active { background: var(--tabl-accent); }

/* ---- Coord readout (live cursor pos w buy mode) ---- */
.tabl-coords { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); z-index: 10; background: var(--tabl-ink); color: var(--tabl-accent); padding: 8px 14px; font-family: var(--tabl-font-mono); font-size: 11px; letter-spacing: 0.05em; opacity: 0; transition: opacity 200ms ease; pointer-events: none; }
.tabl-coords.is-visible { opacity: 1; }

/* ---- Drawer (sidebar zakupu) ---- */
.tabl-drawer { position: absolute; top: 0; right: -440px; width: 420px; height: 100%; background: var(--tabl-canvas-bg); border-left: 1px solid var(--tabl-line-strong); z-index: 30; transition: right 280ms cubic-bezier(0.32, 0.72, 0, 1); overflow-y: auto; }
.tabl-drawer.is-open { right: 0; }
.tabl-drawer-inner { padding: 32px; }

.tabl-drawer-eyebrow { font-family: var(--tabl-font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.18em; color: var(--tabl-ink-dim); margin: 0 0 8px; }
.tabl-drawer h2 { margin: 0 0 24px; font-family: var(--tabl-font-sans); font-size: 28px; font-weight: 600; letter-spacing: -0.02em; line-height: 1.1; }
.tabl-drawer-close { position: absolute; top: 16px; right: 16px; width: 36px; height: 36px; background: transparent; border: 1px solid transparent; font-size: 20px; cursor: pointer; line-height: 1; color: var(--tabl-ink-dim); transition: all 120ms ease; font-family: var(--tabl-font-mono); }
.tabl-drawer-close:hover { color: var(--tabl-ink); border-color: var(--tabl-line-strong); }

/* ---- Drawer info: empty state ---- */
.tabl-info-empty { padding: 18px; background: var(--tabl-bg-dim); border-left: 2px solid var(--tabl-ink); font-size: 13px; line-height: 1.6; color: var(--tabl-ink-dim); margin-bottom: 18px; }
.tabl-info-empty strong { color: var(--tabl-ink); }
.tabl-info-empty .tabl-info-empty-hint { display: block; margin-top: 8px; font-family: var(--tabl-font-mono); font-size: 11px; color: var(--tabl-ink-mute); letter-spacing: 0.02em; }

/* ---- Drawer info: selection state ---- */
.tabl-info-selection { padding: 0; margin-bottom: 24px; }
.tabl-info-grid { display: grid; grid-template-columns: 1fr 1fr; border: 1px solid var(--tabl-line); }
.tabl-info-cell { padding: 14px 16px; border-right: 1px solid var(--tabl-line); border-bottom: 1px solid var(--tabl-line); }
.tabl-info-cell:nth-child(even) { border-right: 0; }
.tabl-info-cell:nth-last-child(-n+2) { border-bottom: 0; }
.tabl-info-cell-label { font-family: var(--tabl-font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--tabl-ink-mute); margin-bottom: 4px; }
.tabl-info-cell-value { font-family: var(--tabl-font-mono); font-size: 14px; color: var(--tabl-ink); font-weight: 500; }

.tabl-info-error { display: none; background: var(--tabl-error-bg); border: 1px solid var(--tabl-error); padding: 12px 14px; margin-top: 12px; font-size: 12px; color: var(--tabl-error); align-items: flex-start; gap: 8px; font-family: var(--tabl-font-mono); }
.tabl-info-error.is-visible { display: flex; }
.tabl-info-error::before { content: '!'; display: inline-flex; align-items: center; justify-content: center; width: 16px; height: 16px; background: var(--tabl-error); color: white; font-weight: 700; flex-shrink: 0; }

/* ---- Cena ---- */
.tabl-info-price-wrap { margin: 24px 0; padding: 24px; background: var(--tabl-ink); color: var(--tabl-bg); position: relative; overflow: hidden; }
.tabl-info-price-wrap::before { content: ''; position: absolute; top: 0; right: 0; width: 80px; height: 80px; background: var(--tabl-accent); transform: translate(40px, -40px) rotate(45deg); }
.tabl-info-price-label { font-family: var(--tabl-font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.18em; color: var(--tabl-ink-mute); margin-bottom: 8px; }
.tabl-info-price { font-family: var(--tabl-font-sans); font-size: 36px; font-weight: 600; letter-spacing: -0.02em; line-height: 1; }
.tabl-info-price-suffix { font-family: var(--tabl-font-mono); font-size: 14px; color: var(--tabl-accent); margin-left: 4px; }

/* ---- Form ---- */
.tabl-form-row { margin-bottom: 18px; }
.tabl-form-row label { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; line-height: 1.5; color: var(--tabl-ink-dim); cursor: pointer; }
.tabl-form-row input[type="checkbox"] { appearance: none; width: 18px; height: 18px; border: 1px solid var(--tabl-line-strong); background: var(--tabl-canvas-bg); cursor: pointer; flex-shrink: 0; margin-top: 1px; position: relative; transition: all 120ms ease; }
.tabl-form-row input[type="checkbox"]:checked { background: var(--tabl-accent); border-color: var(--tabl-line-strong); }
.tabl-form-row input[type="checkbox"]:checked::after { content: ''; position: absolute; left: 4px; top: 0px; width: 6px; height: 12px; border: solid var(--tabl-ink); border-width: 0 2px 2px 0; transform: rotate(45deg); }
.tabl-form-row a { color: var(--tabl-ink); text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; }
.tabl-form-row a:hover { color: var(--tabl-accent-deep); }

.tabl-buy-button { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 16px 20px; background: var(--tabl-accent); color: var(--tabl-ink); border: 1px solid var(--tabl-line-strong); font-family: var(--tabl-font-sans); font-size: 15px; font-weight: 600; letter-spacing: 0.01em; cursor: pointer; box-shadow: 4px 4px 0 var(--tabl-line-strong); transition: all 120ms ease; }
.tabl-buy-button:hover:not(:disabled) { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--tabl-line-strong); }
.tabl-buy-button:active:not(:disabled) { transform: translate(0, 0); box-shadow: 2px 2px 0 var(--tabl-line-strong); }
.tabl-buy-button:disabled { background: var(--tabl-bg-dim); color: var(--tabl-ink-mute); border-color: var(--tabl-line); box-shadow: 4px 4px 0 var(--tabl-line); cursor: not-allowed; }
.tabl-buy-button-arrow { font-family: var(--tabl-font-mono); font-size: 18px; }

/* ---- Mobile ---- */
@media (max-width: 768px) {
    .tabl-stats { top: 16px; left: 16px; padding: 10px 12px; font-size: 11px; box-shadow: 2px 2px 0 var(--tabl-line-strong); }
    .tabl-stats-divider { margin: 0 6px; }
    .tabl-fab { bottom: 16px; right: 16px; padding: 12px 18px; box-shadow: 3px 3px 0 var(--tabl-line-strong); }
    .tabl-zoom-controls { bottom: 16px; left: 16px; box-shadow: 3px 3px 0 var(--tabl-line-strong); }
    .tabl-zoom-controls button { width: 36px; height: 36px; }
    .tabl-coords { bottom: 90px; }
    .tabl-drawer { width: 100%; right: 0; bottom: -100%; top: auto; height: auto; max-height: 70vh; border-left: 0; border-top: 1px solid var(--tabl-line-strong); transition: bottom 280ms cubic-bezier(0.32, 0.72, 0, 1); }
    .tabl-drawer.is-open { bottom: 0; }
    .tabl-drawer-inner { padding: 24px; }
    .tabl-drawer h2 { font-size: 22px; }
    .tabl-info-price { font-size: 28px; }
}
