:root{font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif;color:#fdfcf7;background-color:#04150d;line-height:1.5;font-weight:400;--surface: rgba(10, 28, 20, .88);--surface-strong: rgba(8, 22, 16, .94);--surface-border: rgba(118, 146, 125, .25);--accent: #8bd48c;--accent-strong: #61b96b;--accent-muted: rgba(139, 212, 140, .2);--muted: #c9d4c3;--shadow: 0 24px 48px rgba(2, 10, 6, .65)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;min-height:100%}body.app-body{min-height:100vh;background:radial-gradient(circle at 20% 20%,rgba(67,160,110,.25),transparent 55%),radial-gradient(circle at 80% 0%,rgba(94,59,27,.25),transparent 50%),#04150d;color:#fdfcf7}img,canvas{max-width:100%}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.page-shell{width:min(1100px,100%);margin:0 auto;padding:clamp(1.5rem,4vw,3rem) clamp(1rem,3vw,2.5rem) 3rem;display:flex;flex-direction:column;gap:1.75rem}.page-card{background:var(--surface);border:1px solid var(--surface-border);border-radius:1.5rem;padding:clamp(1.5rem,3vw,2.5rem);box-shadow:var(--shadow);backdrop-filter:blur(16px);display:flex;flex-direction:column;gap:1rem}.hero-card{gap:1.5rem}.page-title{font-size:clamp(2rem,6vw,3rem);margin:0}.page-subtitle{margin:0;color:var(--muted);max-width:60ch}.bilingual-inline{font-size:.9rem;color:var(--muted);margin-left:.35rem;display:inline-block}.eyebrow{text-transform:uppercase;font-size:.75rem;letter-spacing:.2em;color:var(--muted);margin:0}.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.section-title{margin:.25rem 0 0;font-size:1.35rem}.section-description{margin:0;color:var(--muted);font-size:.95rem}.action-row{display:flex;flex-wrap:wrap;gap:.75rem}button{font:inherit;border:none;border-radius:999px;padding:.75rem 1.5rem;cursor:pointer;transition:transform .12s ease,background .15s ease,box-shadow .15s ease}button:active{transform:scale(.97)}.primary-button{background:var(--accent);color:#021a2a;box-shadow:0 10px 20px #8bd48c66}.primary-button:hover{background:var(--accent-strong)}.secondary-button{color:var(--accent);background:var(--accent-muted)}.tertiary-button{color:var(--muted);background:#94a3b81a;border:1px solid var(--surface-border);padding-inline:1rem}.link-button{align-self:flex-start;background:transparent;border:1px solid transparent;border-bottom-color:var(--accent);padding:.25rem 0;font-weight:600}.wood-selector-grid{display:flex;flex-direction:column;gap:1rem}.selector-field{display:flex;flex-direction:column;gap:.35rem}.selector-label{font-size:.85rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted)}.selector-control{width:100%;border-radius:.9rem;border:1px solid var(--surface-border);background:#071a12e6;color:#f8fafc;padding:.65rem .85rem;font:inherit}.selector-control:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.selector-inline{display:flex;gap:.5rem;flex-wrap:wrap}.selector-inline .selector-control{flex:1;min-width:min(260px,100%)}.selector-actions{display:flex;gap:.5rem;flex-wrap:wrap}.selector-help{margin:0;font-size:.85rem;color:var(--muted)}.danger-button{color:#fecaca;border:1px solid rgba(248,113,113,.35);background:#ef44441f}.danger-button:hover{background:#ef444438}.camera-card{gap:1.25rem}.camera-container{position:relative;width:100%;border-radius:1.25rem;border:1px solid var(--surface-border);overflow:hidden;background:#06180fd9;min-height:320px}.camera-start-state{min-height:320px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;text-align:center;color:var(--muted)}.webcam-canvas{width:100%;height:auto;display:block}.webcam-controls{position:absolute;top:.75rem;right:.75rem;display:flex;flex-direction:column;gap:.5rem;z-index:5}.webcam-control-button{width:3rem;height:3rem;border-radius:999px;border:1px solid rgba(255,255,255,.35);background:#06180fcc;color:#f8fafc;font-size:1.3rem;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1;padding:0;box-shadow:0 8px 20px #0206178c}.webcam-control-button:hover{background:#8bd48c59}.wood-display{display:flex;flex-direction:column;gap:1.25rem}.wood-player{border-radius:1.25rem;border:1px solid var(--surface-border);background:var(--surface-strong);padding:.75rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:inset 0 1px #ffffff0a}.wood-player-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.wood-player-title{display:flex;flex-direction:column;gap:.25rem}.player-pill{padding:.25rem .85rem;border-radius:999px;border:1px solid var(--surface-border);background:#94a3b81f;color:var(--muted);font-size:.85rem}.tree-grid{display:flex;flex-direction:column;gap:.5rem}.tree-tile{border:1px solid var(--surface-border);border-radius:1.25rem;padding:.6rem .9rem;background:#081910eb;display:flex;flex-direction:column;gap:.75rem;box-shadow:inset 0 1px #ffffff0a;width:100%;min-height:14rem}.tree-tile-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.tree-title{margin:0;font-size:1.15rem}.tree-title-stack{display:flex;flex-direction:column;gap:.15rem;min-width:0}.tree-title-german{font-size:.75rem;color:var(--muted);font-style:italic}.tree-tag{padding:.2rem .7rem;border-radius:999px;border:1px solid var(--surface-border);font-size:.8rem;color:var(--muted)}.tree-remove-button{background:#ef44441f;color:#fecaca;border:1px solid rgba(248,113,113,.4);padding:.5rem 1rem;border-radius:999px;font-size:.9rem;min-width:2.75rem;text-align:center;transition:background .15s ease,transform .15s ease}.tree-remove-button:hover{background:#ef444438;transform:translateY(-1px)}.tree-slot-grid{display:grid;grid-template-areas:"above above above" "left center right" "below below below";grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:stretch;justify-items:stretch;gap:.3rem}.tree-slot{border:1px dashed rgba(148,163,184,.35);border-radius:1rem;padding:.75rem;background:#06130cbf;min-height:90px;display:flex;flex-direction:column;gap:.4rem;position:relative;overflow:hidden}.tree-slot--above{grid-area:above}.tree-slot--left{grid-area:left}.tree-slot--right{grid-area:right}.tree-slot--below{grid-area:below}.tree-slot--center{grid-area:center;border-style:solid;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(circle at 40% 35%,rgba(141,212,140,.35),transparent 60%),#081910f2;margin:0 auto;padding:.55rem 1rem;width:auto;min-width:0;justify-self:center}.scoreboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.scoreboard-card{border:1px solid var(--surface-border);border-radius:1.25rem;padding:1.25rem;background:#07170fd9;box-shadow:inset 0 1px #ffffff0a;display:flex;flex-direction:column;gap:.85rem}.scoreboard-card-header{display:flex;flex-direction:column;gap:.35rem}.scoreboard-card-title{margin:0;font-size:1.15rem}.scoreboard-total{font-size:2rem;font-weight:700;color:var(--accent)}.scoreboard-badges{display:flex;flex-wrap:wrap;gap:.35rem}.scoreboard-badge{text-transform:uppercase;font-size:.65rem;letter-spacing:.2em;padding:.2rem .75rem;border-radius:999px;border:1px solid var(--surface-border);background:#8bd48c2e;color:var(--accent)}.scoreboard-breakdown{border:1px dashed rgba(148,163,184,.4);border-radius:.95rem;padding:.85rem;display:flex;flex-direction:column;gap:.4rem;background:#06110cb3}.scoreboard-breakdown-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;color:var(--muted)}.scoreboard-breakdown-label{text-transform:uppercase;font-size:.6rem;letter-spacing:.2em}.scoreboard-breakdown-value{font-weight:600;color:#fdfcf7}.scoreboard-empty{margin:0;padding:1rem;text-align:center;color:var(--muted);border-radius:1rem;border:1px dashed var(--surface-border)}.cave-card{gap:1.25rem}.cave-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.85rem}.cave-field{border:1px dashed rgba(139,212,140,.4);border-radius:.85rem;padding:.85rem;display:flex;justify-content:space-between;align-items:center;gap:.75rem;background:#06180fcc}.cave-field span{font-size:.9rem;font-weight:600}.cave-field input{width:5rem;border-radius:.75rem;border:1px solid var(--surface-border);background:#071a12f2;color:#fdfcf7;padding:.35rem .6rem;font:inherit;text-align:right}.cave-field input::-webkit-inner-spin-button,.cave-field input::-webkit-outer-spin-button{margin:0;-webkit-appearance:none}.cave-field input{padding:.75rem .85rem}.slot-label{text-transform:uppercase;font-size:.7rem;letter-spacing:.2em;color:var(--muted);margin:0}.slot-stack{display:flex;flex-direction:column;gap:.35rem;flex:1;max-height:14rem;overflow-y:auto;padding-right:.25rem}.slot-empty{margin:0;font-size:.85rem;color:var(--muted);font-style:italic}.tree-core-title{margin:0;display:flex;flex-direction:column;align-items:center;gap:.1rem;font-size:1rem;text-align:center}.tree-core-title-secondary{font-size:.8rem;color:var(--muted)}.tree-core-subtitle{font-size:.7rem;color:var(--muted)}.animal-chip{border:1px solid var(--surface-border);border-radius:.85rem;padding:.5rem .75rem;background:#63b3662e;display:flex;flex-direction:column;gap:.2rem;min-width:12rem;flex:1 1 12rem;width:100%;box-sizing:border-box}.tree-slot--left .animal-chip,.tree-slot--right .animal-chip{min-width:0;flex:0 0 auto;width:auto}.tree-slot--above .animal-chip,.tree-slot--below .animal-chip{min-width:0;flex:0 0 auto;width:auto;padding-block:.4rem;gap:.1rem}.animal-chip-name-stack{display:flex;flex-direction:column;gap:.05rem;min-width:0}.animal-chip-german{font-size:.75rem;color:var(--muted);font-style:italic;white-space:normal;overflow:visible;text-overflow:clip}.animal-chip--left{background:#be8e4e40}.animal-chip--right{background:#5e997340}.animal-chip--above{background:#7db26340}.animal-chip--below{background:#a06a6340}.animal-chip-header{display:flex;justify-content:flex-start;align-items:center;gap:.5rem}.animal-chip-name{font-weight:600;white-space:normal;word-break:break-word}.animal-chip-meta{display:flex;flex-direction:column;gap:.15rem;font-size:.8rem;color:var(--muted)}.animal-chip-actions{display:flex;justify-content:flex-end}.animal-chip-row{display:flex;flex-direction:column;gap:.35rem;width:100%}.animal-chip-content{display:flex;flex-direction:column;gap:.2rem}.animal-chip-actions .animal-chip-remove{align-self:flex-end}.tree-slot--left .animal-chip-actions,.tree-slot--right .animal-chip-actions{flex-direction:column;align-items:stretch;justify-content:flex-end;margin-top:auto}.tree-slot--left .animal-chip-actions .animal-chip-remove,.tree-slot--right .animal-chip-actions .animal-chip-remove{align-self:center;width:100%}.tree-slot--above .animal-chip-row,.tree-slot--below .animal-chip-row{flex-direction:row;align-items:center;justify-content:space-between;gap:.75rem}.tree-slot--above .animal-chip-content,.tree-slot--below .animal-chip-content{flex:1;min-width:0}.animal-chip-species{font-size:.75rem;color:var(--muted)}.animal-chip-remove{background:transparent;border:none;color:var(--muted);font-size:1.4rem;line-height:1;padding:0;width:2rem;height:2rem;border-radius:.75rem;display:grid;place-items:center;background:#06130c73;transition:background .15s ease,color .15s ease,transform .15s ease}.animal-chip-remove:hover{color:#fecaca;background:#ef444438;transform:translateY(-1px)}.animal-chip-remove:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.license-block{border:1px solid var(--surface-border);border-radius:1rem;background:#06130cbf;padding:1rem}.license-block pre{margin:0;white-space:pre-wrap;font-family:JetBrains Mono,Space Mono,SFMono-Regular,Menlo,Consolas,monospace;font-size:.85rem;color:var(--muted)}.wood-empty{margin:0;padding:1rem;border-radius:.85rem;border:1px dashed var(--surface-border);color:var(--muted);text-align:center;background:#06130cb3}@media(max-width:640px){.section-header{flex-direction:column;align-items:flex-start}.camera-container{min-height:240px}.tree-slot-grid{overflow-x:auto;padding-bottom:.25rem}.tree-slot{min-height:80px}.slot-stack{max-height:none}.tree-slot--center{padding:.55rem;max-width:170px}.tree-core-title{font-size:.95rem}.tree-core-subtitle{font-size:.75rem}}
