/* LYTTELTON FARMS — Brand Stylesheet v2 */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400;1,600&display=swap');

:root {
  --paper:#F0E8D6;--paper-light:#F7F2E8;--ink:#2B1F14;--mid:#5C4B36;
  --rule:#C5B8A0;--wax:#6B2C1A;--white:#FFFFFF;--safe:#4A7C59;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Cormorant Garamond','Georgia','Cambria',serif;background:var(--paper);color:var(--ink);line-height:1.7;-webkit-font-smoothing:antialiased}

/* Layout */
.page{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px 28px}
.page--top{justify-content:flex-start;padding-top:80px}
.container{max-width:560px;width:100%;margin:0 auto}
.container--narrow{max-width:480px}
.container--wide{max-width:680px}

/* Typography */
.invite{font-size:12px;letter-spacing:5px;text-transform:uppercase;color:var(--mid);text-align:center;margin-bottom:56px;font-weight:600}
.wordmark{font-size:16px;letter-spacing:8px;text-align:center;color:var(--ink)}
.wordmark-rule{width:120px;height:2px;background:var(--ink);margin:20px auto 0}
h1{font-size:40px;font-weight:600;text-align:center;color:var(--ink);line-height:1.2;margin:40px 0 12px}
h2{font-size:22px;font-weight:600;color:var(--ink);margin:44px 0 16px}
h3{font-size:20px;font-weight:600;color:var(--ink);margin:32px 0 12px}
p{font-size:17px;line-height:1.8;color:var(--ink);margin-bottom:22px}
.lead{font-size:18px;font-style:italic;color:var(--mid);text-align:center;line-height:1.7}
.accent{font-style:italic;color:var(--mid)}
.strong-line{font-style:italic;color:var(--mid);line-height:1.8}
.text-centre{text-align:center}
.question{font-size:21px;font-style:italic;line-height:1.6;text-align:center}
.bottle{font-size:18px;font-style:italic;line-height:1.8;text-align:center}

/* Decorative */
.rule{width:80px;height:1px;background:var(--rule);margin:36px auto}
.rule--wide{width:160px}
.spacer{height:48px}
.spacer-lg{height:80px}
.commitments{list-style:none;text-align:center;margin:32px 0}
.commitments li{font-size:16px;padding:8px 0;line-height:1.6}
.sig-text{font-size:28px;font-style:italic;text-align:center;margin-top:60px}
.sig-loc{font-size:14px;font-style:italic;color:var(--mid);text-align:center;margin-top:6px}
.private-notice{text-align:center;font-size:12px;font-style:italic;color:var(--rule);padding:14px 0;letter-spacing:1px}

/* Password gate */
.gate{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px 28px;text-align:center}
.gate .lock-icon{font-size:32px;color:var(--rule);margin-bottom:24px}
.gate h2{font-size:28px;margin-bottom:8px;text-align:center}
.gate .gate-sub{font-size:15px;font-style:italic;color:var(--mid);margin-bottom:36px}
.gate input[type="password"]{width:260px;padding:14px 20px;font-family:'Cormorant Garamond','Georgia',serif;font-size:17px;text-align:center;color:var(--ink);background:var(--white);border:1px solid var(--rule);border-radius:4px;outline:none;letter-spacing:3px}
.gate input[type="password"]:focus{border-color:var(--ink)}
.gate .gate-btn{display:block;width:260px;margin:16px auto 0;padding:13px 0;font-family:'Cormorant Garamond','Georgia',serif;font-size:16px;font-style:italic;color:var(--paper);background:var(--ink);border:none;border-radius:4px;cursor:pointer;letter-spacing:1px}
.gate .gate-btn:hover{background:var(--mid)}
.gate .gate-error{font-size:14px;color:var(--wax);font-style:italic;margin-top:16px;min-height:20px}
.gate .gate-note{font-size:13px;color:var(--rule);font-style:italic;margin-top:40px;line-height:1.6}

/* Form elements */
.field{margin-bottom:18px}
.field label{display:block;font-size:15px;color:var(--ink);margin-bottom:6px}
.field input[type="text"],.field input[type="number"],.field input[type="tel"],.field input[type="email"],.field textarea,.field select{width:100%;padding:13px 16px;font-family:'Cormorant Garamond','Georgia',serif;font-size:16px;color:var(--ink);background:var(--white);border:1px solid var(--rule);border-radius:4px;outline:none;-webkit-appearance:none;transition:border-color .2s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--ink)}
.field textarea{min-height:80px;resize:vertical}
.check-group{background:var(--paper-light);border:1px solid var(--rule);border-radius:6px;padding:18px 20px;margin-bottom:20px}
.check-group .group-title{font-size:12px;font-weight:700;color:var(--mid);text-transform:uppercase;letter-spacing:2px;margin-bottom:14px}
.check-item{display:flex;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--rule)}
.check-item:last-child{border-bottom:none}
.check-item input[type="checkbox"]{width:22px;height:22px;margin-right:14px;margin-top:1px;accent-color:var(--ink);flex-shrink:0}
.check-item label{font-size:15px;line-height:1.5;cursor:pointer}
.radio-group{display:flex;gap:24px;flex-wrap:wrap;margin-top:8px}
.radio-item{display:flex;align-items:center;gap:8px}
.radio-item input[type="radio"]{accent-color:var(--ink);width:20px;height:20px}
.radio-item label{font-size:15px}

/* Member cards for wizard form */
.member-card{background:var(--white);border:1px solid var(--rule);border-radius:6px;padding:20px;margin-bottom:16px}
.member-card h4{font-size:16px;color:var(--mid);font-style:italic;margin-bottom:16px;font-weight:400}
.member-row{display:grid;grid-template-columns:1fr 90px;gap:14px}
.add-btn{display:block;width:100%;padding:13px;font-family:'Cormorant Garamond','Georgia',serif;font-size:15px;font-style:italic;color:var(--mid);background:transparent;border:1px dashed var(--rule);border-radius:4px;cursor:pointer;margin-bottom:20px}
.add-btn:hover{border-color:var(--ink);color:var(--ink)}

/* Wizard steps */
.wizard-step{display:none}
.wizard-step.active{display:block}
.step-nav{display:flex;gap:12px;margin-top:32px;justify-content:center}
.step-nav button{padding:12px 36px;font-family:'Cormorant Garamond','Georgia',serif;font-size:16px;border-radius:4px;cursor:pointer;letter-spacing:1px;font-style:italic;transition:all .2s}
.btn-next{color:var(--paper);background:var(--ink);border:none}
.btn-next:hover{background:var(--mid)}
.btn-back{color:var(--mid);background:transparent;border:1px solid var(--rule)}
.btn-back:hover{border-color:var(--ink);color:var(--ink)}
.progress{display:flex;justify-content:center;gap:8px;margin-bottom:32px}
.progress .dot{width:10px;height:10px;border-radius:50%;background:var(--rule);transition:background .3s}
.progress .dot.active{background:var(--ink)}

/* Member health section */
.member-health{background:var(--white);border:1px solid var(--rule);border-radius:8px;padding:24px;margin-bottom:24px}
.member-health .member-name{font-size:20px;font-weight:600;color:var(--ink);margin-bottom:4px}
.member-health .member-meta{font-size:14px;font-style:italic;color:var(--mid);margin-bottom:20px}
.no-conditions{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--paper-light);border:1px solid var(--rule);border-radius:6px;margin-bottom:16px;cursor:pointer}
.no-conditions input{width:20px;height:20px;accent-color:var(--ink)}
.no-conditions label{font-size:15px;color:var(--ink);font-style:italic;cursor:pointer}
.conditions-detail{transition:all .3s}
.conditions-detail.collapsed{display:none}

/* Submit */
.submit-area{text-align:center;margin-top:48px;padding-top:36px;border-top:1px solid var(--rule)}
.submit-btn{display:inline-block;padding:15px 56px;font-family:'Cormorant Garamond','Georgia',serif;font-size:17px;font-style:italic;color:var(--paper);background:var(--ink);border:none;border-radius:4px;cursor:pointer;letter-spacing:1px}
.submit-btn:hover{background:var(--mid)}
.submit-note{font-size:13px;font-style:italic;color:var(--mid);margin-top:18px;line-height:1.6}

/* Menu styling */
.menu-section{margin-bottom:48px}
.menu-section-title{font-size:28px;font-weight:600;text-align:center;margin-bottom:8px}
.menu-section-sub{font-size:14px;font-style:italic;color:var(--mid);text-align:center;margin-bottom:32px;letter-spacing:1px}
.menu-item{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;padding-bottom:8px;border-bottom:1px dotted var(--rule)}
.menu-item:last-child{border-bottom:none}
.menu-item-name{font-size:17px;font-weight:600}
.menu-item-sub{font-size:14px;font-style:italic;color:var(--mid);margin-left:8px;font-weight:400}
.menu-item-price{font-size:16px;white-space:nowrap;margin-left:16px}
.menu-desc{font-size:15px;font-style:italic;color:var(--mid);line-height:1.7;margin:-4px 0 20px;padding-right:80px}

/* Admin styles */
.admin-panel{background:var(--white);border:1px solid var(--rule);border-radius:8px;padding:28px;margin-bottom:24px}
.admin-panel h3{margin-top:0}
.password-output{font-family:monospace;font-size:24px;letter-spacing:4px;text-align:center;padding:20px;background:var(--paper-light);border:1px solid var(--rule);border-radius:6px;margin:16px 0;user-select:all}
.copy-btn{display:block;width:100%;padding:12px;font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--ink);background:var(--paper-light);border:1px solid var(--rule);border-radius:4px;cursor:pointer;text-align:center}
.copy-btn:hover{background:var(--rule);color:var(--white)}

@media(max-width:480px){
  .page,.gate{padding:40px 20px}h1{font-size:32px}h2{font-size:20px}p{font-size:15px}
  .lead{font-size:16px}.question{font-size:19px}.sig-text{font-size:24px}
  .member-row{grid-template-columns:1fr 80px}
  .gate input[type="password"],.gate .gate-btn{width:100%;max-width:280px}
  .menu-desc{padding-right:0}
}
