.page-container{min-height:100vh;padding:clamp(1.25rem,3.5vw,2.5rem) clamp(.9rem,3vw,3rem);background:linear-gradient(180deg,var(--color-bg) 0%,var(--color-surface-soft) 100%);display:flex;flex-direction:column;gap:1rem}.page-container>header{margin-bottom:2rem;display:flex;flex-direction:column;align-items:center;text-align:center}.page-container p{margin:.4rem 0 0;color:var(--color-text-muted)}.app-logo img{display:block;height:clamp(104px,20vw,192px);width:auto}.top-nav{display:inline-flex;align-items:center;gap:.75rem;margin-top:.75rem;padding:.35rem .85rem;border-radius:var(--radius-pill);background:var(--color-surface);border:1px solid var(--color-border-subtle);box-shadow:0 2px 8px #0f172a0f;flex-wrap:wrap;justify-content:center}.top-nav a{text-decoration:none;color:var(--color-text-main);font-weight:600;display:inline-flex;flex-direction:column;align-items:center;gap:.25rem;padding:.35rem .75rem;border-radius:var(--radius-pill);transition:background .15s ease,color .15s ease}.top-nav a.active{background:#0f172a0a}.top-nav__label{display:none}.top-nav a svg{flex-shrink:0}@media(min-width:700px){.top-nav{gap:.35rem;padding:.3rem .6rem}.top-nav a{flex-direction:row;gap:.4rem;padding:.35rem .7rem}.top-nav__label{display:inline;font-size:.9rem;line-height:1}}.user-banner{margin-top:.75rem;display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:var(--color-text-muted)}.user-banner button{cursor:pointer}.user-banner__logout{border-radius:999px;border:1px solid var(--color-border-subtle);background:var(--color-surface);color:var(--color-text-main);font-weight:600;padding:.4rem .9rem;display:inline-flex;align-items:center;gap:.35rem;transition:border-color .2s ease,box-shadow .2s ease,color .2s ease,transform .1s ease}.user-banner__logout:hover{border-color:var(--color-danger);color:var(--color-danger);box-shadow:0 6px 10px #ef44441f;transform:translateY(-1px)}.user-banner__logout-icon{margin-right:.1rem}.page-container__footer{margin-top:auto;text-align:center;padding:1.5rem 0 .5rem;display:flex;flex-direction:column;gap:.35rem}.page-container__footer a{color:var(--color-accent);font-weight:600;text-decoration:none}.page-container__footer a:hover{text-decoration:underline}.home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}.home-card{background:var(--color-surface);border-radius:var(--radius-card);padding:1rem;box-shadow:var(--shadow-card);display:flex;flex-direction:row;align-items:center;gap:1rem;text-decoration:none;color:inherit}.home-card__icon{flex-shrink:0}.home-card__icon svg{stroke-width:1}.home-card__body{display:flex;flex-direction:column;gap:.2rem}.home-card__body h2,.home-card__body p{margin:0}.home-recent{margin-top:2rem;background:var(--color-surface);border-radius:var(--radius-card);padding:1.25rem 1.5rem;box-shadow:var(--shadow-card)}.home-recent h2{margin:0}.home-recent__controls{margin-top:.6rem;display:inline-flex;gap:.35rem;padding:.25rem;border-radius:var(--radius-pill);background:var(--color-surface-soft);border:1px solid var(--color-border-subtle)}.home-recent__toggle{border:none;background:transparent;font:inherit;font-size:.85rem;font-weight:600;color:var(--color-text-muted);padding:.25rem .75rem;border-radius:var(--radius-pill);cursor:pointer;transition:background-color .15s ease,color .15s ease}.home-recent__toggle.is-active{background:var(--color-surface);color:var(--color-text-main);box-shadow:0 1px 3px #0f172a14}.home-recent__toggle:disabled{opacity:.6;cursor:not-allowed}.home-recent__intro{margin:.35rem 0 0;font-size:.9rem;color:var(--color-text-soft)}.home-recent__list{list-style:none;padding:0;margin:.85rem 0 0;display:flex;flex-direction:column;gap:.6rem}.home-recent__item{width:100%;border:1px solid var(--color-border-subtle);border-radius:12px;padding:.55rem .7rem;background:var(--color-surface-soft);display:flex;align-items:center;gap:.6rem;cursor:pointer;text-align:left;font:inherit}.home-recent__item:hover{border-color:var(--color-primary-soft)}.home-recent__photo{flex-shrink:0}.home-recent__photo img{width:40px;height:40px;border-radius:10px;object-fit:cover}.home-recent__content{display:flex;flex-direction:column;gap:.2rem;flex:1}.home-recent__title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.6rem}.home-recent__title{font-weight:600;display:inline-flex;align-items:center;gap:.4rem;margin:0;line-height:1.2}.home-recent__title-badges{display:inline-flex;flex-wrap:wrap;gap:.35rem;justify-content:flex-end}.home-recent__colour-dot{--wine-colour-accent: transparent;width:8px;height:8px;border-radius:999px;background:var(--wine-colour-accent);border:1px solid rgba(17,24,39,.15);flex-shrink:0}.home-recent__colour-dot[data-colour=white]{--wine-colour-accent: #e6d7a8}.home-recent__colour-dot[data-colour=red]{--wine-colour-accent: #a83232}.home-recent__colour-dot[data-colour=rose],.home-recent__colour-dot[data-colour=rosé]{--wine-colour-accent: #e7a2b5}.home-recent__colour-dot[data-colour=orange]{--wine-colour-accent: #d97706}.home-recent__style-pill,.home-recent__quality-pill{border:1px solid var(--color-border-subtle);border-radius:999px;padding:.1rem .6rem;font-size:.75rem;font-weight:600;white-space:nowrap;background:var(--color-surface)}.home-recent__style-pill{background:var(--color-surface-soft);color:var(--color-text-muted)}.home-recent__quality-pill--outstanding,.home-recent__quality-pill--very-good{background:var(--color-success-soft);border-color:#065f4659;color:var(--color-success)}.home-recent__quality-pill--good,.home-recent__quality-pill--acceptable{background:#2563eb0f;border-color:#2563eb40;color:var(--color-text-main)}.home-recent__quality-pill--poor,.home-recent__quality-pill--faulty{background:var(--color-danger-soft);border-color:#b91c1c59;color:var(--color-danger)}.home-recent__quality-pill--unset{background:var(--color-surface-soft);color:var(--color-text-soft)}.home-recent__meta{display:block;font-size:.85rem;color:var(--color-text-soft);margin-top:.15rem;line-height:1.2}.home-recent__meta--secondary{color:var(--color-text-muted);font-size:.8rem;line-height:1.2}.accordion{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card);margin-bottom:1.25rem;scroll-margin-top:8rem}.accordion__header{display:flex;justify-content:space-between;align-items:center;padding:1.1rem 1.5rem;cursor:pointer}.accordion__header-actions{display:inline-flex;align-items:center;gap:.5rem}.accordion__indicator{width:32px;height:32px;border-radius:999px;border:1px solid var(--color-border-subtle);display:flex;align-items:center;justify-content:center;font-size:1.4rem}.accordion__header h2{margin:0;font-size:var(--font-size-h2)}.accordion__header p{margin:.35rem 0 0;color:var(--color-text-soft);font-size:.9rem}.accordion__body{padding:0 1.5rem;max-height:0;opacity:0;overflow:hidden;pointer-events:none;transition:max-height .25s ease,opacity .2s ease,padding-bottom .25s ease}.accordion--open .accordion__body{padding-bottom:1.3rem;max-height:4000px;opacity:1;pointer-events:auto}.form-grid{display:grid;gap:1rem;margin-bottom:1rem}.form-grid--two{grid-template-columns:1fr}.form-grid--four{grid-template-columns:repeat(2,minmax(0,1fr))}@media(min-width:900px){.form-grid--four{grid-template-columns:repeat(4,minmax(0,1fr))}}.form-control{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.form-control label{font-weight:600;font-size:.9rem}.form-control input,.form-control textarea,.form-control select{border:1px solid var(--color-border-subtle);border-radius:10px;padding:.6rem .75rem;font-size:.95rem;font-family:inherit}.form-control textarea{min-height:90px;resize:vertical}.button-group{display:flex;flex-wrap:wrap;gap:.5rem}.button-group__button{border:1px solid var(--color-border-subtle);border-radius:999px;padding:.4rem .9rem;background:var(--color-surface);font:inherit;font-size:.95rem;line-height:1.1;min-height:36px;color:var(--color-text-main);cursor:pointer;transition:all .2s ease}.button-group__button--active{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.button-group__button:hover:not(.button-group__button--active):not(:disabled){background:var(--color-surface-soft);border-color:var(--color-primary-soft)}.button-group__button:disabled{opacity:.6;cursor:not-allowed}.chip-list{display:flex;flex-wrap:wrap;gap:.4rem}.chip{border:1px solid var(--color-border-subtle);border-radius:999px;padding:.4rem .9rem;background:var(--color-surface);font:inherit;font-size:.95rem;line-height:1.1;min-height:36px;color:var(--color-text-main);cursor:pointer;transition:all .2s ease}button.chip:hover:not(.chip--selected):not(.chip--ghost-active):not(:disabled){background:var(--color-surface-soft);border-color:var(--color-primary-soft)}.chip--selected{background:var(--color-accent);color:var(--color-text-inverse);border-color:var(--color-accent)}.chip--ghost{background:transparent;border-color:var(--color-border-subtle);color:var(--color-text-main)}.chip--ghost-active{background:var(--color-primary);color:var(--color-text-inverse)}.btn{border-radius:var(--radius-pill);border:1px solid transparent;padding:.55rem 1.4rem;font-size:.95rem;cursor:pointer;font-weight:600;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .1s ease,box-shadow .1s ease}.btn--md{padding-block:.6rem}.btn--sm{padding-block:.35rem;padding-inline:1rem;font-size:.85rem}.btn--full{width:100%}.btn--primary{background-color:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #0f172a29}.btn--primary.btn--accent{background-color:#2563eb}.btn--primary.btn--accent:hover:not(:disabled){box-shadow:0 10px 20px #2563eb4d}.btn--secondary{background-color:transparent;border-color:var(--color-border-subtle);color:var(--color-text-main)}.btn--secondary:hover:not(:disabled){background-color:var(--color-surface-soft)}.btn--ghost{border-color:transparent;background-color:transparent;color:var(--color-text-main)}.btn--ghost:hover:not(:disabled){background-color:var(--color-surface-soft)}.btn--danger{background-color:var(--color-danger);color:#fff}.btn--danger:hover:not(:disabled){box-shadow:0 10px 20px #b91c1c4d}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.entry-form-page{display:flex;flex-direction:column;gap:1rem;max-width:960px;margin:0 auto;width:100%}.entry-form__header{margin-bottom:0}.entry-form__summary{padding:.85rem 1.1rem;border-radius:14px 14px 0 0;background:var(--color-surface-warm);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:.5rem;text-align:center;align-items:center}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.entry-form__title{margin:0 0 .35rem;font-size:var(--font-size-h1);letter-spacing:.02em;color:var(--color-text-main)}.entry-form__summary-top{display:flex;align-items:center;justify-content:center;gap:1.25rem;margin-top:.5rem;flex-wrap:wrap}.entry-form__mode select{border:1px solid var(--color-border-subtle);border-radius:999px;padding:.35rem .85rem;font:inherit;background:var(--color-surface);color:var(--color-text-main)}.entry-form__level label{display:block;font-weight:600;font-size:.9rem;color:var(--color-text-main);margin-bottom:.25rem}.entry-form__level select{border:1px solid var(--color-border-subtle);border-radius:999px;padding:.35rem .85rem;font:inherit;background:var(--color-surface);color:var(--color-text-main)}.entry-form__intro{margin:0;font-size:.9rem;line-height:1.4;max-width:65ch;color:var(--color-text-muted)}.entry-form__photo{gap:.4rem;align-items:center;text-align:center}.entry-form__photo-hint{margin:0;font-size:.8rem;color:var(--color-text-soft)}.entry-form__photo-input-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:center}.entry-form__photo-preview{cursor:pointer;width:72px;height:72px;border-radius:14px;border:1px dashed var(--color-border-subtle);background:var(--color-surface-soft);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;padding:0;outline:none;border-style:dashed}.entry-form__photo-preview img{width:100%;height:100%;object-fit:cover}.entry-form__photo-placeholder{font-size:.75rem;color:var(--color-text-soft);text-align:center;padding:0 .25rem}.entry-form__photo-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.entry-form__photo-input{font-size:.85rem;display:none}.entry-form__photo-remove{border:none;background:none;padding:0;font-size:.8rem;color:var(--color-text-soft);text-decoration:underline;cursor:pointer}.entry-form__extra-details{margin-top:.75rem;border-radius:16px;border:1px solid var(--color-border-subtle);background:var(--color-surface-soft);padding:.5rem .75rem .75rem}.entry-form__extra-details>summary{list-style:none;cursor:pointer;padding:0}.entry-form__extra-details>summary::-webkit-details-marker{display:none}.entry-form__extra-details-grid{margin-top:.75rem}.entry-form__extra-details-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.entry-form__extra-details-title{font-size:.9rem;font-weight:600}.entry-form__extra-details-toggle{font-size:.8rem;color:var(--color-text-soft);display:inline-flex;align-items:center;gap:.15rem}.entry-form__extra-details-chevron{display:inline-block;transition:transform .15s ease}.entry-form__extra-details[open] .entry-form__extra-details-chevron{transform:rotate(180deg)}.entry-form__nav{position:-webkit-sticky;position:sticky;top:0;z-index:1;padding:0 0 .35rem;background:linear-gradient(180deg,var(--color-bg) 0%,var(--color-surface-soft) 100%)}.entry-form__nav-card{padding:.5rem 1rem;border-radius:0 0 14px 14px;background:var(--color-surface-warm);box-shadow:var(--shadow-card)}.entry-form__nav-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.35rem}.entry-form__nav-label{font-size:.85rem;font-weight:600;color:var(--color-text-main);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entry-form__nav-row{display:flex;align-items:center;gap:.75rem}@media(min-width:769px){.entry-form__nav-row{position:relative;justify-content:center;padding-inline:3.25rem}.entry-form__nav-save{position:absolute;right:0;top:50%;transform:translateY(-50%);z-index:2;box-shadow:var(--shadow-card)}}.entry-form__stepper{display:flex;flex-wrap:nowrap;gap:.75rem;justify-content:center;flex:1 1 auto;min-width:0;overflow-x:auto;padding:0 .25rem .35rem;border-bottom:1px solid var(--color-border-subtle);scroll-snap-type:x proximity}.entry-stepper__step{display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;padding:.4rem .15rem;border-radius:var(--radius-pill);color:var(--color-text-soft);cursor:pointer;position:relative;scroll-snap-align:center;transition:color .15s ease}.entry-stepper__step--current{color:var(--color-text-main)}.entry-stepper__step:hover:not(:disabled){color:var(--color-text-main)}.entry-stepper__step:focus-visible{outline:2px solid var(--color-primary-soft);outline-offset:3px}.entry-stepper__step--current:after{content:"";position:absolute;left:0;right:0;bottom:-.35rem;height:2px;background:var(--color-accent);border-radius:var(--radius-pill)}.entry-stepper__complete{position:absolute;top:-2px;right:-2px;width:14px;height:14px;border-radius:var(--radius-pill);background:var(--color-accent);color:var(--color-text-inverse);font-size:.65rem;display:flex;align-items:center;justify-content:center;border:2px solid var(--color-surface);line-height:1}.entry-stepper__step--current .entry-stepper__complete{background:var(--color-text-inverse);color:var(--color-primary);border-color:var(--color-surface)}.entry-stepper__index{font-weight:600}.entry-stepper__icon{display:block}.entry-form__nav-save{flex-shrink:0;width:48px;height:48px;border-radius:999px;padding:0}.entry-form__nav-save .entry-form__action-icon{margin-right:0}.entry-form__action-icon--saving{opacity:.6}.entry-form__actions{display:flex;gap:.75rem;justify-content:flex-end}.entry-form__reset{background:var(--color-surface);border-color:var(--color-border-subtle)}.entry-form__action-icon,.entry-form__nav-icon-left{margin-right:.35rem}.entry-form__nav-icon-right{margin-left:.35rem}.entry-form__status{margin-top:1rem;padding:.75rem;border-radius:8px;background:var(--color-success-soft);color:var(--color-success);font-weight:600;text-align:right}.entry-form__status--error{background:var(--color-danger-soft);color:var(--color-danger);text-align:left}@media(max-width:768px){.entry-form__header{margin-bottom:.75rem}.entry-form__summary{border-radius:14px;box-shadow:none;border:1px solid var(--color-border-subtle);padding:.9rem 1rem}.entry-form__summary-top{gap:.9rem}.entry-form-page{padding-bottom:calc(7rem + env(safe-area-inset-bottom))}.entry-form__nav{position:fixed;top:auto;bottom:0;left:0;right:0;z-index:10;padding:.55rem .9rem calc(.55rem + env(safe-area-inset-bottom));background:var(--color-surface);border-top:1px solid var(--color-border-subtle);box-shadow:var(--shadow-elevated)}.entry-form__nav-card{padding:0;border-radius:0;background:transparent;box-shadow:none}.entry-form__nav-header{display:none}.entry-form__stepper{justify-content:flex-start;border-bottom:none;padding:0 .5rem .35rem;scroll-padding-inline:.5rem;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}.entry-stepper__step{scroll-snap-align:start}.entry-form .form-control{align-items:center;text-align:center}.entry-form .form-control label{text-align:center}.entry-form .button-group,.entry-form .chip-list{justify-content:center}}.nose-aromas{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.palate-notes{margin-top:1rem}.entry-form .form-control{align-items:stretch;text-align:left}.entry-form .form-control label{text-align:left}.entry-form .form-control input,.entry-form .form-control select,.entry-form .form-control textarea{width:100%}.entry-form .button-group,.entry-form .chip-list{justify-content:center}.nav-buttons{display:flex;justify-content:center;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.button-pill{border-radius:var(--radius-pill);border:1px solid transparent;padding:.55rem 1.4rem;font:inherit;font-size:.95rem;line-height:1.1;cursor:pointer;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;min-height:40px;transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .1s ease,box-shadow .1s ease}.button-pill.primary{background:var(--color-primary);color:var(--color-text-inverse)}.button-pill.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 18px #0f172a2e}.button-pill.secondary{background:transparent;border:1px solid var(--color-border-subtle);color:var(--color-text-main)}.button-pill.secondary:hover:not(:disabled){background:var(--color-surface-soft);border-color:var(--color-primary-soft);transform:translateY(-1px)}.button-pill:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.aroma-block{border:1px solid var(--color-border-subtle);border-radius:16px;padding:1rem;display:flex;flex-direction:column;gap:1rem;background:var(--color-surface-soft);scroll-margin-top:1rem}.aroma-block__header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.aroma-block__header h4{margin:0}.aroma-block__header p{margin:.25rem 0 0;color:var(--color-text-soft);font-size:.85rem}.aroma-block__actions{display:flex;gap:.4rem}.aroma-block__groups{display:flex;flex-direction:column;gap:.75rem}.aroma-block__navs{display:flex;flex-direction:column;gap:.5rem}.aroma-block__summary{display:flex;flex-direction:column;gap:.35rem}.aroma-block__summary-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-soft)}.aroma-block__summary-chips{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:center}.aroma-block__summary-chip{cursor:default;background:var(--color-bg)}.aroma-group{display:flex;flex-direction:column;gap:.5rem;align-items:center}.aroma-group__title{margin:0;width:100%;display:block;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-soft);text-align:center}.aroma-group__descriptors{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}.aroma-nav{display:flex;gap:.75rem;overflow-x:auto;padding:0 .25rem .35rem;border-bottom:1px solid var(--color-border-subtle);justify-content:center;scroll-snap-type:x proximity}.aroma-layer-nav{border-bottom:none;padding-bottom:.15rem}@media(min-width:769px){.aroma-layer-nav{justify-content:center}}.aroma-layer-nav .aroma-nav__item{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.aroma-layer-nav .aroma-nav__item--active{color:var(--color-text-main)}.aroma-layer-nav .aroma-nav__item--active:after{bottom:-.2rem}.aroma-nav__item{border:none;border-radius:0;padding:.4rem .15rem;font-size:.85rem;font-weight:600;background:transparent;color:var(--color-text-soft);cursor:pointer;white-space:nowrap;position:relative;scroll-snap-align:center;transition:color .15s ease}.aroma-nav__item:hover:not(:disabled){color:var(--color-text-main)}.aroma-nav__item:focus-visible{outline:2px solid var(--color-primary-soft);outline-offset:3px}.aroma-nav__item--active{color:var(--color-text-main);font-weight:700}.aroma-nav__item--active:after{content:"";position:absolute;left:0;right:0;bottom:-.35rem;height:2px;background:var(--color-accent);border-radius:var(--radius-pill)}@media(max-width:768px){.aroma-nav{justify-content:flex-start;padding:0 .5rem .35rem;scroll-padding-inline:.5rem;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}.aroma-nav__item{scroll-snap-align:start}}.aroma-panel{border-radius:12px;background:var(--color-surface-soft);padding:.75rem;animation:aroma-panel-in .16s ease}@keyframes aroma-panel-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.aroma-panel__descriptors{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}.section-card{background:var(--color-surface);border-radius:var(--radius-card);padding:1.25rem 1.5rem;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:1rem}.section-card__header h2{margin:0;font-size:var(--font-size-h2)}.section-card__header p{margin:.2rem 0 0;color:var(--color-text-muted);font-size:.9rem}.section-card__header{display:flex;justify-content:space-between;gap:1rem;align-items:center;flex-wrap:wrap}.section-card__actions{display:inline-flex;gap:.5rem}.entries-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.entry-item-container{--wine-colour-accent: transparent;width:100%;border:1px solid var(--color-border-subtle);border-radius:16px;padding:.9rem 1rem;background:var(--color-surface);position:relative;overflow:hidden;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-direction:row;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;font:inherit}.entry-item-container:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--wine-colour-accent);border-radius:16px 0 0 16px;pointer-events:none}.entry-item-container[data-colour=white]{--wine-colour-accent: #e6d7a8}.entry-item-container[data-colour=red]{--wine-colour-accent: #a83232}.entry-item-container[data-colour=rose],.entry-item-container[data-colour=rosé]{--wine-colour-accent: #e7a2b5}.entry-item-container[data-colour=orange]{--wine-colour-accent: #d97706}.entry-item-container[data-colour=other]{--wine-colour-accent: #6b7280}.entry-item__photo,.entry-item__content{position:relative;z-index:1}.entry-item__photo{flex-shrink:0}.entry-item__photo-frame{position:relative;width:68px;height:68px;border-radius:14px;border:1px solid var(--color-border-subtle);background:var(--color-surface-soft);overflow:hidden}.entry-item__photo-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.entry-item__photo-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--color-text-soft)}.entry-item-container:hover{border-color:var(--color-primary-soft);transform:translateY(-1px)}.entry-item-container.is-active{border-color:var(--color-border-strong);box-shadow:0 12px 30px #11182714}.entry-item-container.is-highlighted{border-color:var(--color-accent);box-shadow:0 0 0 1px #2563eb66,0 10px 25px #2563eb26}.entry-item__title{font-weight:600;display:block}.entry-item__title-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.entry-item__style-pill{border:1px solid var(--color-border-subtle);background:var(--color-surface-soft);color:var(--color-text-muted);border-radius:999px;padding:.1rem .6rem;font-size:.75rem;font-weight:600;white-space:nowrap}.entry-item__content{display:flex;flex-direction:column;gap:.2rem;flex:1}.entry-item__meta{display:block;color:var(--color-text-soft);font-size:.85rem;margin-top:.15rem}.entry-item__meta--secondary{color:var(--color-text-muted);font-size:.8rem}.entry-item__owner{display:block;color:var(--color-text-muted);font-size:.8rem;margin-top:.15rem}.entry-item__badges{margin-top:.25rem;display:flex;flex-wrap:wrap;gap:.35rem}.entry-item__badge{border:1px solid var(--color-border-subtle);border-radius:999px;padding:.15rem .7rem;font-size:.78rem;color:var(--color-text-main);white-space:nowrap;background:var(--color-surface-soft)}.entry-item__badge--muted{color:var(--color-text-soft)}.entry-item__badge--quality-outstanding,.entry-item__badge--quality-very-good{background:var(--color-success-soft);border-color:#065f4659;color:var(--color-success)}.entry-item__badge--quality-good,.entry-item__badge--quality-acceptable{background:#2563eb0f;border-color:#2563eb40;color:var(--color-text-main)}.entry-item__badge--quality-poor,.entry-item__badge--quality-faulty{background:var(--color-danger-soft);border-color:#b91c1c59;color:var(--color-danger)}.entry-item__badge--quality-unset{color:var(--color-text-soft)}.entries-controls{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;align-items:center}.entries-control{display:flex;flex-direction:column;gap:.2rem;font-size:.8rem;color:var(--color-text-muted)}.entries-control--search{flex:1 1 220px;min-width:180px}.entries-search{width:100%;border:1px solid var(--color-border-subtle);border-radius:999px;background:var(--color-surface);padding:.35rem .85rem;font:inherit;color:var(--color-text-main)}.entries-search::placeholder{color:var(--color-text-soft)}.entries-search:focus{border-color:var(--color-primary-soft);outline:2px solid var(--color-primary-soft);outline-offset:2px}.entries-clear{align-self:center}.entries-control--layout{display:none}.entries-layout-toggle.is-active{background:var(--color-surface-soft);border-color:var(--color-border-subtle)}@media(min-width:900px){.entries-control--layout{display:inline-flex;flex-direction:row;gap:.35rem;align-items:center}.entries-list--grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.entries-list--grid .entries-list__item{height:100%}.entries-list--grid .entry-item-container{flex-direction:column;align-items:stretch;gap:.75rem;height:100%}.entries-list--grid .entry-item__photo-frame{width:100%;height:160px}.entries-list--grid .entry-item__photo-img{width:100%;height:100%;object-fit:cover}}.entries-control span{display:inline-flex;align-items:center;gap:.25rem}.entries-control__icon{margin-right:.1rem}.entries-control select{border:1px solid var(--color-border-subtle);border-radius:999px;background:var(--color-surface);padding:.35rem .75rem;font:inherit;color:#111827;cursor:pointer}.entries-control select:focus{border-color:var(--color-primary-soft);outline:2px solid var(--color-primary-soft);outline-offset:2px}.entries-control--filter{align-items:center}.entries-control--compact span{display:none}.entries-filter{position:relative}.entries-filter>summary{list-style:none;cursor:pointer;border-radius:999px;border:1px solid var(--color-border-subtle);background:var(--color-surface);padding:.35rem .75rem;font-size:.8rem;display:inline-flex;align-items:center;gap:.25rem}.entries-filter>summary::-webkit-details-marker{display:none}.entries-filter[open]>summary{background:var(--color-surface-soft)}.entries-filter__options{position:absolute;z-index:2;margin-top:.3rem;padding:.5rem .75rem;border-radius:.75rem;background:#fff;box-shadow:0 10px 24px #0f172a29;min-width:160px;display:grid;gap:.3rem}.entries-filter__option{display:flex;align-items:center;gap:.35rem;font-size:.8rem}.entries-filter__option input{margin:0}.entries-list__empty{border:1px dashed var(--color-border-subtle);border-radius:18px;padding:1rem 1.25rem;background:var(--color-surface-soft);text-align:center;color:var(--color-text-muted);font-size:.9rem;line-height:1.4}.entries-empty__cta{margin-top:.75rem;border-radius:999px;border:none;padding:.6rem 1.4rem;background:var(--color-primary);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer}.entries-pagination{margin-top:1.25rem;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;font-size:.9rem;color:var(--color-text-main)}.entries-pagination__controls{display:flex;align-items:center;gap:.75rem}.entry-view{display:flex;flex-direction:column;gap:1.5rem}.entry-view__summary-grid{display:grid;grid-template-columns:minmax(0,260px) minmax(0,1fr);grid-template-rows:auto auto;gap:1rem;align-items:flex-start}.entry-view__summary-photo{grid-row:1 / span 2;grid-column:1}.entry-view__photo-box{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card);overflow:hidden}.entry-view__photo-box img{display:block;width:100%;height:auto;object-fit:cover}.entry-view__summary-context{grid-row:1;grid-column:2}.entry-view__summary-details{grid-row:2;grid-column:2}.entry-view__summary-grid--no-photo{grid-template-columns:1fr;grid-template-rows:auto auto}.entry-view__summary-grid--no-photo .entry-view__summary-context,.entry-view__summary-grid--no-photo .entry-view__summary-details{grid-column:1}.entry-view__meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.entry-view__meta-block span{display:block;font-size:.85rem;color:var(--color-text-soft)}.entry-view__meta-block strong{font-size:1.05rem;color:var(--color-text-main)}@media(max-width:768px){.entry-view__summary-grid{grid-template-columns:1fr;grid-template-rows:auto auto auto}.entry-view__summary-photo,.entry-view__summary-context,.entry-view__summary-details{grid-column:1;grid-row:auto}}.entry-view__group{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin:0}.entry-view__group--column{grid-template-columns:1fr}.section-card__body .entry-view__group+.entry-view__group,.section-card__body .entry-view__group+.entry-view__chips,.section-card__body .entry-view__chips+.entry-view__group{margin-top:1rem}.entry-view__group-row{display:flex;flex-direction:column;gap:.25rem;border:1px solid var(--color-border-subtle);border-radius:12px;padding:.75rem;background:var(--color-surface-soft)}.entry-view__group-row dt{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin:0}.entry-view__group-row dd{margin:0;font-size:1rem;color:var(--color-text-main)}.entry-view__chips{margin-top:1rem;display:flex;flex-direction:column;gap:.4rem}.entry-view__chips-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-soft)}.entry-view__chips-list{display:flex;flex-wrap:wrap;gap:.4rem}.entry-view__chip{border:1px solid var(--color-border-subtle);border-radius:999px;padding:.2rem .75rem;background:#fff;font-size:.85rem}.entry-view__chips-empty{color:#9ca3af;font-size:.9rem}.entry-view__link{display:inline-flex;margin-top:.75rem;color:var(--color-accent);font-weight:600;text-decoration:none}.entry-view__actions{display:flex;justify-content:flex-end;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.entry-view__back{margin-right:auto}.entry-view__action-icon{margin-right:0}.entry-view__markdown{background:#0f172a;color:#f8fafc;padding:1rem;border-radius:12px;overflow-x:auto;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.9rem;line-height:1.4;white-space:pre-wrap}.entry-markdown-view{display:flex;flex-direction:column;gap:1rem}.entry-markdown-view__actions{display:flex;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.entry-markdown-view__icon{margin-right:.35rem}.entry-markdown-view__body{background:#0f172a;color:#f8fafc;padding:1rem;border-radius:12px;overflow-x:auto;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.9rem;line-height:1.4;white-space:pre-wrap}.login-panel{max-width:420px;margin:0rem auto;padding:2rem;border-radius:1rem;background:var(--color-surface);box-shadow:var(--shadow-elevated)}.login-panel h2{margin:0 0 .5rem}.login-panel p{margin:0 0 1.5rem;color:var(--color-text-muted)}.login-panel form{display:flex;flex-direction:column;gap:1rem}.login-panel label{display:flex;flex-direction:column;font-weight:600;gap:.35rem;color:var(--color-text-main)}.login-panel input{padding:.65rem .75rem;border:1px solid var(--color-border-subtle);border-radius:.5rem;font-size:1rem}.login-panel__error{margin:0;color:#b91c1c;font-weight:600}.login-panel__submit{background-image:linear-gradient(110deg,#0f172a,#312e81);border-color:transparent;font-size:1rem}.login-panel__submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-panel__submit:disabled{opacity:.6;cursor:not-allowed}.login-panel__hint{margin-top:1.5rem;font-size:.95rem}.login-panel__hint a{color:var(--color-accent);font-weight:600}.signup-panel{max-width:520px;margin:0rem auto;padding:2rem;border-radius:1rem;background:var(--color-surface);box-shadow:var(--shadow-elevated)}.signup-panel h2{margin:0 0 .5rem}.signup-panel p{margin:0 0 1.5rem;color:var(--color-text-muted)}.signup-panel form{display:flex;flex-direction:column;gap:1rem}.signup-panel label{display:flex;flex-direction:column;font-weight:600;gap:.35rem;color:var(--color-text-main)}.signup-panel input{padding:.65rem .75rem;border:1px solid var(--color-border-subtle);border-radius:.5rem;font-size:1rem}.signup-panel__error{margin:0;color:#b91c1c;font-weight:600}.signup-panel__submit{background-image:linear-gradient(110deg,#022c58,#0f766e);border-color:transparent;font-size:1rem}.signup-panel__submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.signup-panel__submit:disabled{opacity:.6;cursor:not-allowed}.signup-panel__hint{margin-top:1.5rem;font-size:.95rem}.signup-panel__hint a{color:var(--color-accent);font-weight:600}.admin-dashboard{margin-top:0rem}.admin-dashboard .section-card+.section-card{margin-top:1.5rem}.admin-dashboard__tabs{display:inline-flex;border-radius:999px;background:#e5e7eb;padding:.25rem;margin-bottom:1.5rem}.admin-dashboard__tabs button{border:none;background:transparent;padding:.5rem 1.25rem;border-radius:999px;font-weight:600;cursor:pointer;transition:background .2s ease}.admin-dashboard__tabs button.is-active{background:#111827;color:#fff}.admin-dashboard__error{color:#b91c1c;font-weight:600;margin-bottom:1rem}.admin-dashboard__panel table{width:100%;border-collapse:collapse;background:var(--color-surface);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-card)}.admin-dashboard__panel th,.admin-dashboard__panel td{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;text-align:left}.admin-dashboard__panel th{background:var(--color-surface-soft);font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;color:#6b7280}.admin-dashboard__panel tr:last-child td{border-bottom:none}.admin-dashboard__invite-header{margin-bottom:1.25rem;padding:1rem 1.25rem;border-radius:.75rem;background:var(--color-surface-soft);box-shadow:var(--shadow-card)}.admin-dashboard__actions{display:flex;flex-wrap:wrap;gap:.5rem}.admin-dashboard__actions button{font-size:.9rem}.admin-dashboard__action-icon{margin-right:.3rem}.admin-dashboard__badge{font-weight:600;text-transform:capitalize}.admin-dashboard__invite-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.admin-dashboard__invite-form label{display:flex;flex-direction:column;gap:.35rem;font-weight:600}.admin-dashboard__invite-form input{border:1px solid #d1d5db;border-radius:.5rem;padding:.5rem}.admin-dashboard__invite-form button{font-weight:600}.admin-dashboard__invite-code{margin-bottom:1rem;padding:.75rem 1rem;border-radius:.75rem;background:#ecfccb;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.admin-dashboard__invite-code button{border:none;border-radius:.5rem;padding:.35rem .85rem;background:#1d4ed8;color:#fff;cursor:pointer}.admin-dashboard__message{margin:0 0 1rem;color:#065f46;font-weight:600}.signup-pref-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-top:.5rem}.signup-pref-tile{border-radius:.9rem;border:1px solid #d1d5db;padding:.75rem .9rem;background:#f9fafb;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.signup-pref-tile input[type=radio]{display:none}.signup-pref-tile__title{font-weight:600}.signup-pref-tile--active{border-color:#111827;background:#111827;color:#fff;box-shadow:0 0 0 1px #111827}.signup-pref-tile__description{display:block;font-size:.8rem;color:inherit;opacity:.9}.changelog{background:var(--color-surface);padding:2rem;border-radius:20px;box-shadow:var(--shadow-elevated);display:flex;flex-direction:column;gap:1.75rem}.changelog__header h1{margin:0 0 .35rem;font-size:1.4rem}.changelog__header p{margin:0;color:var(--color-text-muted)}.changelog-entry{border-left:4px solid #a855f7;padding-left:1.5rem}.changelog-entry__meta{display:flex;flex-direction:column;gap:.25rem}.changelog-entry__meta h2{margin:0;font-size:1.25rem}.changelog-entry__meta span{color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.changelog-entry__description{margin:.75rem 0;color:var(--color-text-main)}.changelog-entry__summary{background:#f5f3ff;border-radius:16px;padding:1rem 1.25rem}.changelog-entry__summary h3{margin:0 0 .5rem;font-size:.95rem;color:#6d28d9}.changelog-entry__summary ul{margin:0;padding-left:1rem;color:#4b5563}.changelog-entry__summary li{margin-bottom:.4rem}.changelog-entry__details h3{margin:0;font-size:.95rem;color:#374151}.changelog-entry__details-toggle{margin:1rem 0 .4rem;padding:0;border:none;background:transparent;display:inline-flex;align-items:center;gap:.35rem;font-size:.95rem;font-weight:600;color:#374151;cursor:pointer}.changelog-entry__highlights{margin:0;padding-left:1rem;color:#1f2937}.changelog-entry__details-chevron{display:inline-block;transition:transform .15s ease}.changelog-entry__details-chevron.is-open{transform:rotate(180deg)}.changelog-entry__highlights li{margin-bottom:.5rem}.logged-out-home{margin:0rem auto 0;max-width:520px;display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center}.logged-out-home__tagline{margin:0;font-size:1rem;color:var(--color-text-muted)}.logged-out-home__hint{margin:.75rem 0 0;font-size:.95rem;color:var(--color-text-muted)}.logged-out-home__hint a{color:var(--color-accent);font-weight:600;text-decoration:none}.logged-out-home__hint a:hover{text-decoration:underline}.about{max-width:720px;margin:0rem auto;background:var(--color-surface);border-radius:var(--radius-card);padding:2rem;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:1.5rem}.about__header{text-align:center}.about__header h1{margin:0;font-size:2rem}.about__header p{margin:.5rem 0 0;color:var(--color-text-muted)}.about__body p{margin:0;font-size:1rem;line-height:1.6;color:var(--color-text-main)}.about__body a{color:var(--color-accent);font-weight:600;text-decoration:none}.about__body a:hover{text-decoration:underline}.about__body p+p{margin-top:1rem}:root{--font-family-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-body: clamp(15px, 1.6vw, 17px);--font-size-h1: clamp(24px, 3vw, 32px);--font-size-h2: clamp(18px, 2.2vw, 22px);--font-size-h3: clamp(15px, 1.9vw, 18px);--font-size-meta: 12px;--font-size-base: var(--font-size-body);--line-height-base: 1.55;--color-bg: #f6f3ee;--color-surface: #ffffff;--color-surface-soft: #fbfaf7;--color-surface-warm: #f6eee4;--color-border-subtle: #e5e7eb;--color-border-strong: #111827;--color-text-main: #1f2937;--color-text-muted: #4b5563;--color-text-soft: #6b7280;--color-text-inverse: #ffffff;--color-primary: #111827;--color-primary-soft: #cbd5f5;--color-accent: #2563eb;--color-danger: #b91c1c;--color-danger-soft: #fee2e2;--color-success: #065f46;--color-success-soft: #ecfdf5;--shadow-card: 0 8px 22px rgba(15, 23, 42, .12);--shadow-elevated: 0 16px 36px rgba(15, 23, 42, .18);--radius-card: 18px;--radius-pill: 999px;font-family:var(--font-family-sans);color:var(--color-text-main);background-color:var(--color-bg);line-height:var(--line-height-base)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-size:var(--font-size-base)}a{color:inherit}
