@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Playfair+Display:wght@600;700&display=swap');
.hgb *,.hgb *::before,.hgb *::after{margin:0;padding:0;box-sizing:border-box}
.hgb{font-family:'DM Sans',sans-serif;color:#2c2c2c;max-width:800px;margin:0 auto;background:#f5f0e8;border-radius:16px;overflow:hidden}
.hgb-hero{background:linear-gradient(135deg,#0e4a6e 0%,#1a8a7a 55%,#25ad99 100%);padding:32px 20px 24px;text-align:center}
.hgb-hero h2{font-family:'Playfair Display',serif;font-size:clamp(22px,5vw,32px);color:#fff;font-weight:700;line-height:1.15}
.hgb-hero h2 em{color:#d4a843;font-style:normal}
.hgb-hero p{color:rgba(255,255,255,.65);margin-top:6px;font-size:13px}
.hgb-form{padding:20px}
.hgb-section{margin-bottom:20px;background:#fff;border-radius:12px;padding:16px;border:1px solid rgba(0,0,0,.04)}
.hgb-stitle{font-family:'Playfair Display',serif;font-size:18px;color:#0e4a6e;font-weight:600;margin-bottom:4px}
.hgb-ssub{font-size:12px;color:#6b6b6b;margin-bottom:14px}
.hgb-label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:#6b6b6b;font-weight:600;margin-bottom:5px;margin-top:12px}
.hgb-label:first-child{margin-top:0}
.hgb-select{appearance:none;width:100%;background:#f9f7f3;border:1.5px solid #e0d9ce;border-radius:8px;padding:10px 32px 10px 12px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;color:#2c2c2c;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%236b6b6b' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}
.hgb-select:focus{outline:none;border-color:#25ad99;box-shadow:0 0 0 3px rgba(37,173,153,.15)}
.hgb-row{display:flex;gap:12px;flex-wrap:wrap}
.hgb-row>*{flex:1;min-width:140px}
.hgb-slider-wrap{display:flex;align-items:center;gap:12px}
.hgb-slider{flex:1;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;background:#e0d9ce;outline:none;cursor:pointer}
.hgb-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:#25ad99;border:3px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.15);cursor:pointer}
.hgb-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#25ad99;border:3px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.15);cursor:pointer}
.hgb-sval{font-size:18px;font-weight:700;color:#0e4a6e;min-width:50px;text-align:center;font-family:'Playfair Display',serif}
.hgb-counters{display:flex;gap:12px;flex-wrap:wrap}
.hgb-counter{flex:1;min-width:140px;background:#f9f7f3;border-radius:10px;padding:12px;display:flex;align-items:center;justify-content:space-between;border:1.5px solid #e0d9ce}
.hgb-counter-label{font-size:14px;font-weight:500}
.hgb-counter-label small{display:block;font-size:11px;color:#6b6b6b;font-weight:400}
.hgb-counter-ctrls{display:flex;align-items:center;gap:8px}
.hgb-cbtn{width:30px;height:30px;border-radius:50%;border:1.5px solid #e0d9ce;background:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#2c2c2c;font-weight:600;line-height:1;transition:all .15s}
.hgb-cbtn:hover{border-color:#25ad99;color:#25ad99}
.hgb-cnum{font-size:18px;font-weight:700;color:#0e4a6e;min-width:22px;text-align:center}
.hgb-opts{display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(95px,1fr))}
.hgb-opt{background:#f9f7f3;border:2px solid #e0d9ce;border-radius:10px;padding:10px 6px;text-align:center;cursor:pointer;transition:all .2s}
.hgb-opt:hover{border-color:#48bca2}
.hgb-opt.hgb-on{border-color:#25ad99;background:rgba(37,173,153,.07);box-shadow:0 0 0 3px rgba(37,173,153,.1)}
.hgb-opt-icon{font-size:24px}
.hgb-opt-name{font-size:11px;font-weight:600;color:#0e4a6e;margin-top:2px}
.hgb-opt-price{font-size:10px;color:#6b6b6b;margin-top:1px}
.hgb-toggle{display:flex;align-items:center;justify-content:space-between;background:#f9f7f3;border-radius:8px;padding:10px 12px;border:1.5px solid #e0d9ce;margin-bottom:8px;cursor:pointer}
.hgb-toggle-text{font-size:13px;font-weight:500}
.hgb-toggle-text small{display:block;font-size:11px;color:#6b6b6b;font-weight:400}
.hgb-sw{position:relative;width:44px;height:24px;flex-shrink:0}
.hgb-sw input{opacity:0;width:0;height:0;position:absolute}
.hgb-sw-track{position:absolute;inset:0;background:#ccc;border-radius:12px;transition:background .2s;cursor:pointer}
.hgb-sw-track::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.12)}
.hgb-sw input:checked+.hgb-sw-track{background:#25ad99}
.hgb-sw input:checked+.hgb-sw-track::after{transform:translateX(20px)}
.hgb-actcat{font-size:11px;font-weight:600;color:#25ad99;text-transform:uppercase;letter-spacing:.5px;margin:10px 0 4px;padding-top:8px;border-top:1px solid #eee}
.hgb-actcat:first-child{border-top:none;padding-top:0;margin-top:0}
.hgb-act{display:flex;align-items:center;gap:8px;background:#f9f7f3;border-radius:8px;padding:8px 10px;border:1.5px solid #e0d9ce;cursor:pointer;transition:all .15s;margin-bottom:6px}
.hgb-act:hover{border-color:#48bca2}
.hgb-act.hgb-on{border-color:#25ad99;background:rgba(37,173,153,.05)}
.hgb-act input{display:none}
.hgb-ack{width:18px;height:18px;border:2px solid #ccc;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px;color:transparent;transition:all .15s}
.hgb-act.hgb-on .hgb-ack{background:#25ad99;border-color:#25ad99;color:#fff}
.hgb-act-t{flex:1;font-size:12px;font-weight:500;line-height:1.3}
.hgb-act-t small{display:block;font-size:10px;color:#6b6b6b;font-weight:400}
.hgb-act-p{font-size:11px;font-weight:600;color:#0e4a6e;white-space:nowrap}
.hgb-repas-bar{display:flex;align-items:center;gap:6px}
.hgb-repas-bar span{font-size:11px;color:#6b6b6b;white-space:nowrap}
.hgb-repas-val{text-align:center;margin-top:6px;font-size:12px;color:#6b6b6b}
.hgb-calc{display:block;width:100%;padding:14px;border:none;border-radius:10px;background:linear-gradient(135deg,#d4a843 0%,#b8922e 100%);color:#fff;font-family:'DM Sans',sans-serif;font-size:16px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s;margin-top:10px}
.hgb-calc:hover{opacity:.9;transform:translateY(-1px)}

/* RESULTS */
.hgb-res{display:none;padding:0 20px 24px}
.hgb-res.hgb-show{display:block}
.hgb-cur{display:flex;gap:6px;justify-content:center;margin-bottom:14px}
.hgb-cur button{padding:4px 12px;border-radius:20px;border:1.5px solid #e0d9ce;background:#fff;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;cursor:pointer;color:#6b6b6b;transition:all .15s}
.hgb-cur button.hgb-curon{background:#0e4a6e;color:#fff;border-color:#0e4a6e}
.hgb-totcard{background:linear-gradient(135deg,#0e4a6e 0%,#1a8a7a 100%);border-radius:14px;padding:24px;text-align:center;margin-bottom:16px}
.hgb-totlabel{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.55)}
.hgb-totnum{font-family:'Playfair Display',serif;font-size:clamp(34px,8vw,48px);font-weight:700;color:#d4a843;line-height:1;margin:4px 0 8px}
.hgb-totsub{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;font-size:12px;color:rgba(255,255,255,.65)}
.hgb-totsub strong{color:#fff}
.hgb-bk{margin-bottom:16px}
.hgb-bki{background:#fff;border-radius:10px;padding:12px;border:1px solid rgba(0,0,0,.04);margin-bottom:8px}
.hgb-bkh{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.hgb-bkcat{font-size:13px;font-weight:600;color:#0e4a6e}
.hgb-bkamt{font-size:14px;font-weight:700;color:#2c2c2c}
.hgb-bkbar{height:7px;border-radius:4px;background:#f0ebe3;overflow:hidden;margin-bottom:5px}
.hgb-bkfill{height:100%;border-radius:4px;transition:width .5s}
.hgb-bkdet{font-size:11px;color:#6b6b6b;line-height:1.4}
.hgb-bktip{font-size:11px;color:#25ad99;margin-top:3px;font-style:italic}
.hgb-bkcta{display:inline-block;margin-top:4px;font-size:11px;font-weight:600;color:#d4a843;text-decoration:none}
.hgb-bkcta:hover{color:#b8860b}
.hgb-cmp{background:#fff;border-radius:10px;padding:12px;border:1px solid rgba(0,0,0,.04);margin-bottom:16px}
.hgb-cmp-title{font-size:12px;font-weight:600;color:#0e4a6e;margin-bottom:8px}
.hgb-cmp-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.hgb-cmp-lbl{font-size:11px;color:#6b6b6b;min-width:60px}
.hgb-cmp-bw{flex:1;height:8px;background:#f0ebe3;border-radius:4px;overflow:hidden}
.hgb-cmp-f{height:100%;border-radius:4px}
.hgb-cmp-val{font-size:11px;font-weight:600;color:#0e4a6e;min-width:55px;text-align:right}
.hgb-tips{background:#fff;border-radius:10px;padding:12px;border:1px solid rgba(0,0,0,.04);margin-bottom:16px}
.hgb-tips-title{font-size:12px;font-weight:600;color:#0e4a6e;margin-bottom:6px}
.hgb-tip{font-size:11px;color:#2c2c2c;padding:5px 0;border-bottom:1px solid #f5f0e8;line-height:1.4}
.hgb-tip:last-child{border-bottom:none}
.hgb-tip b{color:#25ad99}
.hgb-restart{text-align:center;padding-bottom:8px}
.hgb-restart button{background:none;border:1.5px solid #e8725a;color:#e8725a;border-radius:8px;padding:8px 18px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}
.hgb-restart button:hover{background:#e8725a;color:#fff}
@media(max-width:500px){.hgb-counters{flex-direction:column}.hgb-opts{grid-template-columns:repeat(3,1fr)}.hgb-totsub{flex-direction:column;align-items:center;gap:4px}}
