:root{
  --bg:#1c1013; --panel:#271619; --panel2:#321c21; --line:#43282e;
  --wine:#6d152b; --wine2:#b5294b; --cream:#f3e3c3; --text:#efe2e4; --muted:#b39aa0;
  --ok:#3fb27f; --bad:#e0613f; --radius:14px;
  --accent:#6d152b; --accent2:#b5294b; --field:#1a0e11;
}
/* motyw per moduł: akcent + tinty tła/paneli/pól (wino = domyślny burgund) */
.theme-whisky{--accent:#7a4a1a; --accent2:#a9701f;
  --bg:#17110a; --panel:#221a10; --panel2:#2c2113; --line:#3d2f1a; --field:#15100a}
.theme-beer{--accent:#8a6f16; --accent2:#b8951e;
  --bg:#161208; --panel:#201c0d; --panel2:#2a2410; --line:#3a3219; --field:#141007}
.theme-coffee{--accent:#7a4a2e; --accent2:#a9744a;
  --bg:#160f0a; --panel:#221710; --panel2:#2c2014; --line:#3d2e20; --field:#140d08}
.theme-tea{--accent:#3f7a4a; --accent2:#5da46c;
  --bg:#0d130e; --panel:#141d16; --panel2:#19261c; --line:#26352a; --field:#0c120d}
.cat-coffee{background:#7a4a2e}
.cat-tea{background:#3f7a4a}
#app{background:var(--bg);min-height:100dvh}
*{box-sizing:border-box}
[x-cloak]{display:none!important}
html,body{margin:0;background:var(--bg);color:var(--text);overflow-x:hidden;
  font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-text-size-adjust:100%}
h1,h2,h4{margin:.2em 0 .4em}
code{background:#0003;padding:.1em .35em;border-radius:6px;font-size:.9em}
.muted{color:var(--muted)} .small{font-size:.82rem} .grow{flex:1}
button{font:inherit;cursor:pointer;border:none;border-radius:10px;padding:.55em .9em;
  background:var(--panel2);color:var(--text);border:1px solid var(--line)}
button:hover{border-color:var(--accent2)}
button.primary{background:var(--accent);border-color:var(--accent);color:#fff}
button.primary:hover{background:var(--accent2)}
button.big{padding:.8em 1.4em;font-size:1.05rem;width:100%}
.link{background:none;border:none;color:var(--muted);padding:.4em .6em;font-size:1rem;
  line-height:1.5;margin:0;display:inline-flex;align-items:center;cursor:pointer}
.link:hover{color:var(--cream)}
.link.danger{color:var(--bad)}
input,select,textarea{font:inherit;width:100%;min-width:0;background:var(--field);color:var(--text);
  border:1px solid var(--line);border-radius:10px;padding:.55em .7em}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent2)}
input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(0.85);opacity:.85;cursor:pointer}
label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:.7em}
label input,label select,label textarea{margin-top:.25em;color:var(--text)}

/* ekrany centralne */
.center{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:24px;gap:10px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;max-width:460px}
.config p,.login p{color:var(--muted)}
.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--accent2);
  border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* aplikacja */
.app{max-width:880px;margin:0 auto;padding:0 14px 80px;padding-top:env(safe-area-inset-top)}
.topbar{position:sticky;top:0;z-index:10;display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;
  padding:12px 2px;background:linear-gradient(var(--bg),var(--bg) 70%,transparent);}
.langbreak{display:none}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;padding:.4em}
.iconbtn .lucide{width:1.35em;height:1.35em;display:block}
.brand{font-weight:700;font-size:1.2rem;color:var(--cream);cursor:pointer}
.user{font-size:.85rem;color:var(--muted);max-width:40vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dot{width:10px;height:10px;border-radius:50%}
.dot.on{background:var(--ok)} .dot.off{background:var(--bad)}
.actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:4px 0 14px}
.newbtn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;font-size:1.08rem;font-weight:600;padding:.9em 1em;margin:0 0 14px}
.newbtn .lucide{width:1.2em;height:1.2em}
/* przycisk instalacji PWA (ekrany startowe, przed logowaniem) */
.install-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-top:14px;background:var(--panel2);border:1px solid var(--accent2);color:var(--cream);border-radius:10px;padding:.6em 1.1em;font-size:.95rem;cursor:pointer}
.install-btn:hover{background:var(--panel)}
.install-btn .lucide{width:1.15em;height:1.15em}
.ioshint{margin:8px auto 0;max-width:300px}
/* logowanie e-mail + hasło */
.authsep{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:.8rem;margin:14px 0 10px}
.authsep::before,.authsep::after{content:"";flex:1;border-top:1px solid var(--line)}
.authsep span{padding:0 10px}
.emailauth{display:flex;flex-direction:column;gap:8px;text-align:left}
.emailauth input{width:100%}
.authrow{display:flex;gap:8px}
.authrow .primary,.authrow .secondary{flex:1}
.emailauth .secondary{background:var(--panel2);border:1px solid var(--line);color:var(--text);border-radius:10px;padding:.55em .7em;cursor:pointer}
.emailauth .secondary:hover{border-color:var(--accent2)}
.emailauth .link.small{align-self:flex-start;font-size:.82rem;padding:.2em 0}
.authmsg{color:var(--accent2)}
/* reklamy w wersji Free */
.adbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--accent2);border-radius:10px;padding:10px 14px;margin:0 0 14px;text-decoration:none;color:var(--text);cursor:pointer}
.adbar:hover{border-color:var(--accent)}
.adbar-thumb{flex:0 0 auto;width:64px;height:64px;object-fit:cover;border-radius:8px}
.adbar-tx{flex:1 1 160px;font-size:.9rem}
.adbar-cta{flex:0 0 auto;background:var(--accent);color:#fff;border-radius:8px;padding:.45em .9em;font-size:.88rem;white-space:nowrap}
.admodal{position:fixed;inset:0;z-index:1100;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;padding:24px}
.admodal-card{max-width:360px;width:100%;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;text-align:center;display:flex;flex-direction:column;gap:10px}
.admodal-card h3{margin:0;color:var(--accent2)}
.admodal-img{max-width:100%;height:auto;border-radius:10px;display:block;cursor:pointer}
.admodal-skip{align-self:center}
.admodal-skip[disabled]{opacity:.55;cursor:default}
/* Panel admina: reklamy */
.adtoggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;margin:6px 0}
.adtoggle input{width:auto}
.adknobs{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;margin:10px 0 16px}
.adknobs label{display:flex;flex-direction:column;gap:4px;font-size:.88rem}
.adknobs input[type=number]{width:90px}
.aditem{border:1px solid var(--line);border-radius:10px;padding:12px;margin:0 0 12px;display:flex;flex-direction:column;gap:8px;background:var(--panel2)}
.aditem-top{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.aditem-top select{margin-left:auto}
.aditem-row{display:flex;flex-wrap:wrap;gap:8px}
.aditem-row input{flex:1 1 160px}
.aditem-prev{max-width:160px;height:auto;border-radius:8px}
.chip.del{border-color:var(--bad);color:var(--bad);cursor:pointer}
.file{position:relative;overflow:hidden;display:inline-flex;align-items:center}
.file input{position:absolute;inset:0;opacity:0;cursor:pointer}

.banner{background:#3a2a10;border:1px solid #6a5320;color:#e9d9a8;border-radius:10px;
  padding:.6em .9em;font-size:.85rem;margin-bottom:12px}
hr{border:none;border-top:1px solid var(--line);margin:18px 0}

/* filtry */
.filters{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.filters input[type=search]{grid-column:1/-1}

/* lista kart */
.cards{display:flex;flex-direction:column;gap:10px}
.winecard{display:flex;gap:12px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:10px;cursor:pointer;transition:border-color .15s}
.winecard:hover{border-color:var(--accent2)}
.thumb{flex:0 0 56px;width:56px;height:72px;border-radius:8px;display:flex;align-items:center;
  justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;overflow:hidden;background:var(--accent)}
.thumb.cat-coffee{background:#7a4a2e} .thumb.cat-tea{background:#3f7a4a}
.thumb.k-white{background:#9a8a3f} .thumb.k-rose{background:#b5566f}
.thumb.k-sparkling{background:#8a8f5a} .thumb.k-dessert{background:#9a6a2f} .thumb.k-fortified{background:#7a3a2a}
.thumb.cat-whisky{background:#7a4a1a} .thumb.cat-beer{background:#9a7d1f}
.catemoji{font-size:1.7rem;line-height:1}
.catswitch,.cattabs{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 14px}
.catpick{background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:.5em 1em;color:var(--text)}
.catpick.on{background:var(--accent);border-color:var(--accent);color:#fff}
.quicktoggle{display:inline-flex;margin:0 0 14px;border:1px solid var(--line);border-radius:20px;overflow:hidden}
.quicktoggle button{background:var(--panel2);border:none;border-radius:0;color:var(--muted);padding:.5em 1.1em}
.quicktoggle button.on{background:var(--accent);color:#fff}
.formtoggles{display:flex;flex-wrap:wrap;align-items:center;gap:14px 18px;margin:0 0 14px}
.formtoggles .quicktoggle{margin:0}
.switch{display:inline-flex;align-items:center;gap:9px;cursor:pointer;margin:0;font-size:.9rem;color:var(--text)}
.switch input{position:absolute;opacity:0;width:0;height:0}
.switch-track{position:relative;width:42px;height:24px;flex:0 0 auto;border-radius:24px;background:var(--panel2);border:1px solid var(--line);transition:background .15s,border-color .15s}
.switch-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--muted);transition:transform .15s,background .15s}
.switch input:checked + .switch-track{background:var(--accent);border-color:var(--accent)}
.switch input:checked + .switch-track .switch-knob{transform:translateX(18px);background:#fff}
.switch input:focus-visible + .switch-track{border-color:var(--accent2)}
.thumb img{width:100%;height:100%;object-fit:cover}
.glassicon{color:var(--cream);opacity:.92}
.ico{display:inline-flex;align-items:center;justify-content:center;vertical-align:-0.18em}
.lucide{width:1.15em;height:1.15em;display:block}
.ico.big .lucide{width:1.9em;height:1.9em}
.brand .lucide{width:1.25em;height:1.25em}
/* Montserrat (wordmark marki, self-host) */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:300;font-display:swap;src:url('/fonts/montserrat-300.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:300;font-display:swap;src:url('/fonts/montserrat-300-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/montserrat-800.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/montserrat-800-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
/* Logo marki GustoNote (znak + wordmark) */
.gn-brand{display:inline-flex;align-items:center;gap:8px}
.gn-mark{width:26px;height:26px;flex:0 0 auto}
.gn-wm{font-family:'Montserrat',Arial,sans-serif;font-weight:800;letter-spacing:-.3px;color:var(--cream);line-height:1}
.gn-wm b{font-weight:300}
h1 .gn-brand{gap:10px}
h1 .gn-mark{width:32px;height:32px}
.winecard .info{flex:1;min-width:0}
.winecard .row{display:flex;justify-content:space-between;gap:8px;align-items:baseline}
.winecard strong{font-size:1.05rem}
.winecard .sub{color:var(--muted);font-size:.85rem;margin:.1em 0 .4em}
.score{background:var(--accent);color:#fff;border-radius:8px;padding:.05em .5em;font-weight:700}
.score.big{font-size:1.3rem;padding:.1em .55em}
.tags{display:flex;flex-wrap:wrap;gap:5px}
.pill{background:var(--accent);color:#fff;border-radius:20px;padding:.12em .65em;font-size:.78rem}
.pill.ghost{background:#0000;border:1px solid var(--line);color:var(--muted)}
.pill.fault{background:var(--bad);color:#fff}

/* formularz */
.formhead,.formfoot{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:6px 0 14px}
.formhead h2{flex:1;text-align:center;font-size:1.1rem}
.card2{border:1px solid var(--line);border-radius:var(--radius);margin:0 0 16px;background:var(--panel);overflow:hidden}
.cardhead{background:var(--panel2);border-bottom:1px solid var(--line);padding:11px 14px;color:var(--cream);font-weight:600}
.cardbody{padding:14px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid2 .full{grid-column:1/-1}
.grid2>*,.filters>*{min-width:0}
.inline{display:flex;gap:6px} .inline .cur{flex:0 0 64px;text-align:center}
.photo .lbl{display:block;font-size:.85rem;color:var(--muted);margin-bottom:.4em}
.photobtns{display:flex;gap:8px;flex-wrap:wrap}
.btnlike{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:6px;
  background:var(--panel2);border:1px solid var(--line);color:var(--text);
  border-radius:10px;padding:.55em .9em;cursor:pointer;font-size:.92rem;margin:0}
.btnlike:hover{border-color:var(--accent2)}
.btnlike input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.photoprev{display:flex;align-items:center;gap:10px;margin-top:8px}
.photoprev img{max-height:120px;border-radius:8px;border:1px solid var(--line)}

/* autouzupełnianie */
.suggest{background:#0002;border:1px dashed var(--line);border-radius:10px;padding:8px;margin:-4px 0 12px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}

/* picker szczepów */
.grapepick{margin-top:.25em}
.gsuggest{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.chip.add{border-style:dashed;color:var(--cream)}

/* koło aromatów */
.selected{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.aromasearch{margin-bottom:8px}
.recent{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:10px}
.chip{background:var(--panel2);border:1px solid var(--line);color:var(--text);border-radius:20px;
  padding:.3em .8em;font-size:.85rem}
.chip.sel{background:var(--accent);border-color:var(--accent);color:#fff}
.chip.fault.sel{background:var(--bad);border-color:var(--bad)}
.wheel{display:flex;flex-direction:column;gap:6px}
.cats{display:flex;flex-direction:column;gap:14px}
.catgroup{}
.catgrouphead{display:flex;gap:8px;align-items:baseline;color:var(--cream);font-weight:600;margin-bottom:8px}
.catbtns{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
.catbtn{position:relative;display:flex;align-items:center;justify-content:center;gap:8px;text-align:center;
  min-height:64px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:.7em .9em}
.catbtn:hover{border-color:var(--accent2)}
.catbtn.sel{background:var(--accent);border-color:var(--accent);color:#fff}
.catbtn.fault.sel{background:var(--bad);border-color:var(--bad);color:#fff}
.catbtn .cnt{position:absolute;top:6px;right:6px;background:var(--accent);color:#fff;border-radius:20px;
  min-width:1.5em;text-align:center;font-size:.78rem;padding:.05em .4em}
.subview .back{margin:0 0 8px;display:inline-block}
.subglabel{font-size:.78rem;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
.aromas{display:flex;flex-wrap:wrap;gap:6px}
.faults{margin-top:14px;border-top:1px dashed var(--line);padding-top:10px}
.faults h4{color:var(--bad)}
.subg{margin-bottom:8px}

/* ocena */
.scorebox{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}
.scorebox label{flex:0 0 140px}
.stars{display:flex;gap:2px}
.star{background:none;border:none;font-size:1.7rem;color:var(--line);padding:0 .05em}
.star.on{color:#e8b84b}
.buyagain{display:flex;align-items:center;gap:8px;margin:12px 0}
.check{display:flex;align-items:center;gap:8px}
.check input{width:auto;margin:0}

/* szczegóły */
.detail .dhead{display:flex;gap:14px;align-items:flex-start}
.dphoto{max-height:160px;border-radius:10px;border:1px solid var(--line)}
.dgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:14px 0}
.notes{white-space:pre-wrap;background:#0002;border:1px solid var(--line);border-radius:10px;padding:10px}
/* Radar sensoryczny */
.radarbox{margin:14px 0}
.radarbox h4{margin:0 0 4px}
.radarwrap{display:flex;justify-content:center}
.radarsvg{width:100%;max-width:480px;height:auto;display:block}
/* karta szczegółu w stylu PDF: ornament + ramki sekcji + nagłówki z ikoną w akcencie */
.detail .detailbody{border-top:4px solid var(--accent2);padding-top:18px;margin-top:4px}
.dcard{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin:14px 0}
.dcard .dgrid{margin:0}
.dsec-h{display:flex;align-items:center;gap:7px;margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid var(--line);
  color:var(--accent2);font-size:.92rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.dsec-h .muted{text-transform:none;letter-spacing:normal}
.dsec-ico{display:inline-flex;flex:0 0 auto;color:var(--accent2)}
.dsec-ico .lucide{width:16px;height:16px}
.dscore{display:inline-flex;align-items:center;gap:8px;vertical-align:middle}
.dstars{display:inline-flex;align-items:center}
.calib-toggle{display:inline-flex;align-items:center;gap:6px;margin-bottom:8px;font-size:.85rem;color:var(--muted);cursor:pointer;user-select:none}
.calib-toggle input{cursor:pointer}
.calib-toggle-btn{margin:0 0 8px;padding-left:0;color:var(--accent2);font-weight:600}

/* profil & statystyki */
.insights .formhead h2{flex:1;text-align:center;font-size:1.1rem}
.statrow{display:flex;gap:10px;margin-bottom:10px}
.stat{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:10px;
  padding:10px;text-align:center;display:flex;flex-direction:column;gap:2px}
.stat .big{font-size:1.6rem;font-weight:700;color:var(--cream)}
.bar{display:flex;align-items:center;gap:8px;margin:5px 0}
.barlabel{flex:0 0 36%;font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bartrack{flex:1;background:#0003;border-radius:6px;height:12px;overflow:hidden}
.barfill{display:block;height:100%;background:var(--accent2)}
.barval{flex:0 0 auto;color:var(--muted);font-size:.82rem;min-width:1.5em;text-align:right}
.proflike{display:flex;flex-wrap:wrap;gap:6px;align-items:center}

/* admin */
.adminuser{display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px;padding:10px 0;border-bottom:1px solid var(--line)}
.au-info{display:flex;flex-direction:column;min-width:0;gap:2px}
.au-info span{overflow:hidden;text-overflow:ellipsis}
.au-ent{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.au-modules{display:flex;flex-direction:column;gap:6px;width:100%}
.au-mod{display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.au-mname{min-width:56px;font-size:.85rem;color:var(--muted)}
.au-date{width:auto;flex:0 0 auto;padding:.3em .5em;font-size:.85rem}

/* edytor treści */
.content-editor .ed-group{border:1px solid var(--line);border-radius:10px;padding:10px;margin-bottom:12px}
.content-editor .ed-grouphead{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.content-editor .ed-glabel{font-weight:700;color:var(--cream);background:#0002;flex:1}
.content-editor .ed-sub{border-left:2px solid var(--line);padding:6px 0 6px 10px;margin:8px 0}
.content-editor .ed-subhead{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.content-editor .ed-slabel{flex:1;background:#0002}
.content-editor .ed-aroma{display:flex;align-items:center;gap:8px;margin:4px 0}
.content-editor .ed-aroma input{flex:1;min-width:0}
.content-editor .ed-aroma.hidden input{opacity:.5;text-decoration:line-through}
.content-editor .ed-aroma .code{flex:0 0 auto}
.content-editor .ed-add{display:flex;gap:6px;align-items:center;margin:6px 0}
.content-editor .ed-add input{flex:1;min-width:0}
.content-editor .ed-add .chip{flex:0 0 auto;white-space:nowrap}
.content-editor .ed-list{margin:14px 0;padding-top:10px;border-top:1px dashed var(--line)}
.content-editor .ed-list h4{margin:0 0 8px}
.banner.warn{background:#4a2410;border-color:#8a4a1e;color:#f0c89a;display:flex;align-items:center;gap:8px}
.unsaved{margin-right:auto;color:#f0a35a;font-weight:600;font-size:.85rem}
.langsel{width:auto;flex:0 0 auto;max-width:120px;background:transparent;color:var(--muted);border:1px solid var(--line);border-radius:8px;padding:2px 22px 2px 8px;font-size:.82rem;cursor:pointer}
.langsel option{background:var(--panel);color:var(--text)}
.content-editor .transtable{max-height:560px;overflow:auto;border:1px solid var(--line);border-radius:8px;padding:4px 10px;margin:6px 0}
/* Tłumaczenia: jeden język naraz (2 szerokie kolumny) */
.translangtabs{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}
.transtools{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin:6px 0}
.transtools .aromasearch{flex:1 1 240px;margin:0}
.transstats{margin-left:auto;white-space:nowrap}
.transhead2{display:grid;grid-template-columns:1fr 1.4fr;gap:16px;font-size:.76rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;padding:4px 0;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel2);z-index:1}
.transrow2{display:grid;grid-template-columns:1fr 1.4fr;gap:16px;align-items:start;padding:7px 0;border-bottom:1px solid var(--line)}
.transrow2.miss{border-left:3px solid var(--accent2);padding-left:8px;margin-left:-8px}
.transpl2{min-width:0;word-break:break-word;line-height:1.35;padding-top:6px}
.transinput{width:100%;min-height:38px;resize:vertical;line-height:1.35;font:inherit;overflow:hidden}
.content-editor .typstruct{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0}
.content-editor .typsel{flex:1 1 22%;min-width:110px}
.content-editor .typsel span{display:block;font-size:.78rem;color:var(--muted);margin-bottom:2px}
.content-editor .typsel input{width:100%}
.content-editor .tagh{display:block;font-size:.8rem;color:var(--muted);margin-bottom:4px}
.content-editor label.full{display:block;margin:8px 0}
.content-editor label.full input{width:100%}

/* suwaki sensoryki SCA */
.sliders{display:flex;flex-direction:column;gap:2px}
.slider-row{display:flex;align-items:center;gap:10px;padding:5px 0}
.slider-row .slabel{flex:0 0 42%;font-size:.9rem}
.slider-row input[type=range]{flex:1;accent-color:var(--accent2);min-width:0;width:auto}
.slider-row .sval{flex:0 0 2.8em;text-align:right;font-variant-numeric:tabular-nums;color:var(--cream);font-weight:600}
.scatotal{display:flex;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}
.scatotal strong{color:var(--cream);font-size:1.15rem}

/* toast */
.toast{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);background:var(--cream);
  color:#2a1418;padding:.7em 1.2em;border-radius:30px;font-weight:600;box-shadow:0 6px 24px #0008;z-index:50;max-width:90vw;text-align:center}

@media (max-width:560px){
  .grid2,.dgrid{grid-template-columns:1fr}
  .filters{grid-template-columns:1fr}
  .user{display:none}
}
@media (max-width:760px){
  .actions .grow,.formhead .grow{display:none}
  .actions,.formhead{gap:6px 10px}
  .actions .link,.formhead .link{padding:.5em .55em}
  .topbar .langbreak{display:block;flex-basis:100%;height:0}
  .topbar .langsel{margin-left:auto}
  /* suwaki: każdy na osobny wiersz, pełna szerokość */
  .slider-row{flex-wrap:wrap;gap:4px 10px;padding:10px 0}
  .slider-row .slabel{order:1;flex:1 1 auto}
  .slider-row .sval{order:2;flex:0 0 auto;text-align:right}
  .slider-row input[type=range]{order:3;flex:1 1 100%;width:100%;height:30px}
}

/* Kalibracja (typowość) */
.calib-wrap{margin-top:14px}
.blindtoggle{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--muted);cursor:pointer;margin-bottom:8px}
.blindtoggle input{width:auto}
.calib{border:1px solid var(--line);border-radius:10px;padding:12px;margin:6px 0;background:#0002}
.calib h4{margin:0 0 4px;display:flex;align-items:center;gap:8px}
.calibrows{display:flex;flex-direction:column;gap:4px;margin:8px 0}
.calibrow{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.calibrow .ck{flex:0 0 30%;font-weight:600}
.calibrow .cv{flex:1;min-width:0}
.calibrow.hit .ck{color:var(--ok)}
.calibrow.near .ck{color:#e8b84b}
.calibrow.miss .ck{color:var(--bad)}
.csum{margin:4px 0;font-size:.9rem}
.csum.near{color:#e8b84b}
.csum.miss{color:var(--bad)}
.calib.blind{background:#0003}

/* Druk / PDF - karta degustacji (widoczna tylko przy drukowaniu) */
.printcard{display:none}
@media print{
  @page{size:A4;margin:14mm}
  html,body{background:#fff}
  .app,.toast{display:none!important}
  .printcard{display:block!important;color:#000;font-size:11pt;line-height:1.4;font-family:Georgia,'Times New Roman',serif;border-top:5px solid var(--pc-accent);padding-top:8px;position:relative;overflow:hidden}
  .printcard *{color:#000!important;box-shadow:none!important}
  /* Znak wodny (tylko Free, przełącznik w panelu reklam) */
  .pc-watermark{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6mm;transform:rotate(-28deg);pointer-events:none;z-index:5;opacity:.09;overflow:hidden}
  .pc-watermark span{font-family:'Montserrat',Arial,sans-serif;font-weight:800;font-size:64pt;letter-spacing:-1.5px;line-height:1;color:var(--pc-accent)!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .pc-watermark small{font-size:15pt;letter-spacing:.4em;text-transform:uppercase;color:var(--pc-accent)!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .pc-brand{display:flex;align-items:center;gap:7px;margin-bottom:12px}
  .pc-mark{width:22px;height:22px;flex:0 0 auto}
  .pc-wm{font-family:'Montserrat',Arial,sans-serif;font-weight:800;font-size:13pt;letter-spacing:-.3px;color:#7a2226!important}
  .pc-wm b{font-weight:300}
  .pc-sep{color:#aaa!important}
  .pc-niche{font-size:9pt;letter-spacing:.12em;text-transform:uppercase;color:#555!important}
  .pc-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border-bottom:2px solid var(--pc-accent);padding-bottom:4px;margin:2px 0 6px}
  .pc-title h1{font-size:23pt;font-weight:600;letter-spacing:-.2px;margin:0;line-height:1.08}
  .pc-scorewrap{display:flex;flex-direction:column;align-items:center;gap:3px}
  .pc-stars{display:flex}
  .pc-score{font-size:18pt;font-weight:800;border:2px solid var(--pc-accent);color:var(--pc-accent)!important;border-radius:8px;padding:2px 10px;min-width:42px;text-align:center}
  .pc-sub{font-size:11pt;font-weight:700}
  .pc-meta{font-size:9pt;color:#555!important;margin-bottom:8px}
  .pc-cols{display:flex;gap:18px}
  .pc-cols .pc-block{flex:1}
  .pc-block{margin:8px 0;break-inside:avoid}
  .printcard .pc-block h2{font-size:11pt;text-transform:uppercase;letter-spacing:.03em;color:var(--pc-accent)!important;border-bottom:1px solid var(--pc-accent);margin:0 0 4px;padding-bottom:2px;display:flex;align-items:center;gap:5px}
  .printcard .pc-ico{color:var(--pc-accent)!important;display:inline-flex;flex:0 0 auto}
  .printcard .pc-ico .lucide{width:13px;height:13px}
  .pc-row2{display:flex;gap:12px;align-items:stretch;break-inside:avoid;margin:10px 0}
  .pc-col-l{flex:1 1 50%}
  .pc-col-r{flex:1 1 50%;display:flex;flex-direction:column}
  .pc-framed{border:1px solid #d6ccbe;border-radius:8px;padding:8px 12px;break-inside:avoid;margin:8px 0}
  .pc-framed h2:not(:first-child){margin-top:9px}
  .pc-radar .radarsvg{max-width:300px;margin:0 auto}
  .pc-col-r .pc-radar{flex:1;display:flex;align-items:center;justify-content:center}
  .pc-col-r .pc-radar .radarsvg{max-width:100%}
  .pc-kv{width:100%;border-collapse:collapse;font-size:10pt}
  .pc-kv td{padding:1px 0;vertical-align:top}
  .pc-kv td:first-child{color:#555!important;width:44%;padding-right:8px}
  .pc-sens,.pc-cal{display:flex;flex-wrap:wrap;gap:3px 14px;font-size:10pt}
  .pc-tags{display:flex;flex-wrap:wrap;gap:5px}
  .pc-tag{border:1px solid var(--pc-accent);border-radius:10px;padding:1px 8px;font-size:9.5pt}
  .pc-tag.fault{border-color:#b00;color:#b00!important;font-weight:700}
  .printcard p{margin:3px 0}
  .pc-photo{max-width:60mm;max-height:60mm;margin-top:8px;border:1px solid #999}
  .pc-foot{margin-top:14px;border-top:1px solid #999;padding-top:4px;font-size:8pt;color:#777!important}
}

/* Lista „Do kupienia" */
.wishform{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.wishform input{flex:1 1 160px;min-width:0}
.wishform .primary{flex:0 0 auto}
.buylist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.buyitem{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--panel2)}
.buyitem .bi-main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1 1 auto}
.buyitem .bi-main a{word-break:break-all}
.buyitem.click{cursor:pointer}
