@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700;900&family=Lato:wght@300;400;700&family=Playfair+Display+SC:wght@400;700&display=swap');

:root {
    --bg:#f5f0e6;--bg-dark:#ede5d0;--bg-card:#faf7f0;
    --ink:#2c1a0e;--ink-light:#5c3d1e;--ink-faint:#9c7a5a;
    --green:#3a5c3a;--green-dark:#2a4628;--green-light:#4e7a4e;--green-bg:#eef4ee;
    --gold:#8b6914;--gold-light:#c9a227;--red:#7a2020;
    --border:#c8b48a;--border-dark:#8b6914;--shadow:rgba(44,26,14,0.15);
    --font-heading:'Playfair Display',Georgia,serif;
    --font-sc:'Playfair Display SC',Georgia,serif;
    --font-body:'Lato',Helvetica,sans-serif;
    --radius:4px;--transition:0.2s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{background-color:var(--bg);color:var(--ink);font-family:var(--font-body);font-weight:400;line-height:1.6;min-height:100vh}
a{color:var(--green);text-decoration:none}
a:hover{color:var(--green-dark);text-decoration:underline}

#site-header{background-color:var(--bg-card);background-image:url('../img/bg-classic.svg');background-size:cover;background-position:center;color:var(--ink);text-align:center;padding:2rem 1rem 1.6rem;border-bottom:4px double var(--gold-light)}
.header-ornament{color:var(--gold);font-size:1rem;letter-spacing:.6em;display:block;margin:.4rem 0;font-family:var(--font-body);font-weight:300;text-transform:uppercase}
#site-title{margin-bottom:.4rem;line-height:1}
#site-logo{height:clamp(52px,8vw,80px);width:auto;max-width:100%;display:inline-block;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35))}
#site-tagline{font-family:var(--font-body);font-style:italic;font-weight:300;font-size:clamp(.9rem,2vw,1.05rem);color:var(--ink-faint);letter-spacing:.05em}

#main-content{max-width:1200px;margin:0 auto;padding:2rem 1rem 4rem;display:grid;grid-template-columns:1fr 340px;column-gap:2rem;row-gap:0;align-items:start}
#search-section{grid-column:1;grid-row:1}
#results-section{grid-column:1;grid-row:2}
#list-section{grid-column:2;grid-row:1/span 2;position:sticky;top:1rem}

.panel{background:var(--bg-card);border:1px solid var(--border);border-top:3px solid var(--green);border-radius:var(--radius);padding:1.6rem 1.8rem;box-shadow:0 2px 12px var(--shadow)}
.panel-title{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--ink);margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}
.panel-title .icon{color:var(--green);font-size:1.1rem}
.panel-subtitle{font-size:.82rem;color:var(--ink-faint);font-style:italic;margin-bottom:1.2rem;border-bottom:1px solid var(--border);padding-bottom:.8rem}

#search-section{background:var(--bg-card);border:1px solid var(--border);border-top:4px double var(--gold);border-bottom:4px double var(--gold);border-radius:var(--radius);padding:2rem 2rem 1rem;box-shadow:0 3px 18px var(--shadow);text-align:center}
#search-section .section-heading{font-family:var(--font-heading);font-size:clamp(1.1rem,3vw,1.45rem);font-weight:600;color:var(--ink);margin-bottom:1.4rem}
#search-form{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end;justify-content:center}
.form-group{display:flex;flex-direction:column;gap:.3rem;text-align:left}
.form-group label{font-size:.8rem;font-weight:700;color:var(--ink-light);text-transform:uppercase;letter-spacing:.06em}
.form-group.query-group{flex:1 1 320px}
.form-group.radius-group{flex:0 0 160px}
input[type="text"],select{width:100%;padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:1rem;transition:border-color var(--transition),box-shadow var(--transition);outline:none}
input[type="text"]:focus,select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(58,92,58,.12)}
input[type="text"]::placeholder{color:var(--ink-faint);font-style:italic}
select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235c3d1e' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .8rem center;padding-right:2.2rem}

.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1.4rem;border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:.92rem;font-weight:700;cursor:pointer;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);text-decoration:none;letter-spacing:.03em;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--green);color:#fff;border-bottom:3px solid var(--green-dark);font-size:1rem;padding:.75rem 2rem}
.btn-primary:hover{background:var(--green-light);box-shadow:0 4px 12px rgba(58,92,58,.3);text-decoration:none;color:#fff}
.btn-secondary{background:var(--bg-dark);color:var(--ink);border:1.5px solid var(--border)}
.btn-secondary:hover{background:var(--border);color:var(--ink);text-decoration:none}
.btn-danger{background:transparent;color:var(--red);border:1px solid var(--red);padding:.3rem .7rem;font-size:.78rem}
.btn-danger:hover{background:var(--red);color:#fff;text-decoration:none}
.btn-outline-green{background:transparent;color:var(--green);border:1.5px solid var(--green)}
.btn-outline-green:hover{background:var(--green-bg);text-decoration:none}
.btn-small{padding:.35rem .8rem;font-size:.8rem}

#location-status{font-size:.82rem;color:var(--ink-faint);margin-top:.9rem;font-style:italic;min-height:1.2em}
#location-status.success{color:var(--green)}
#location-status.error{color:var(--red)}

#results-placeholder{text-align:center;color:var(--ink-faint);padding:3rem 1rem;font-style:italic;font-size:1.05rem}
#results-placeholder .big-icon{font-size:3rem;display:block;margin-bottom:.8rem;opacity:.4}
.results-count{font-size:.82rem;color:var(--ink-faint);font-style:italic}

#results-table-wrap{overflow-x:auto;margin-top:1rem;border:1px solid var(--border);border-radius:var(--radius)}
#results-table{width:100%;border-collapse:collapse;font-size:.92rem}
#results-table thead tr{background:var(--green-dark);color:#fff}
#results-table thead th{padding:.7rem .9rem;text-align:left;font-family:var(--font-body);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}
#results-table tbody tr{border-bottom:1px solid var(--bg-dark);transition:background var(--transition)}
#results-table tbody tr:nth-child(even){background:var(--bg-dark)}
#results-table tbody tr:hover{background:var(--green-bg)}
#results-table tbody tr.rank-1{background:#f0f8f0}
#results-table td{padding:.7rem .9rem;vertical-align:middle}
.td-rank{font-family:var(--font-heading);font-weight:700;color:var(--ink-faint);font-size:.85rem;width:2rem;text-align:center}
.rank-1 .td-rank{color:var(--gold);font-size:1rem}
.td-shop strong{display:block;font-weight:700;color:var(--ink)}
.td-brand{color:var(--ink-light);font-size:.85rem}
.td-product{max-width:220px}
.td-product .product-name{font-weight:600;color:var(--ink);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.td-type{white-space:nowrap}
.td-distance{white-space:nowrap;font-size:.88rem;color:var(--ink-light)}
.td-dist-none{color:var(--ink-faint)}
.distance-online{color:var(--ink-faint);font-style:italic}
.td-price{font-family:var(--font-heading);font-weight:700;font-size:1.05rem;color:var(--green-dark);white-space:nowrap}
.rank-1 .td-price{font-size:1.15rem}
.td-actions{text-align:center;white-space:nowrap}
.btn-add{background:var(--green);color:#fff;border:none;border-radius:var(--radius);padding:.32rem .75rem;font-size:.78rem;font-weight:700;cursor:pointer;transition:background var(--transition);white-space:nowrap}
.btn-add:hover{background:var(--green-light)}
.btn-add.added{background:var(--gold);cursor:default}
.btn-add:disabled{opacity:.7;cursor:default}

.spinner{display:inline-block;width:1.2rem;height:1.2rem;border:2px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:.4rem}
@keyframes spin{to{transform:rotate(360deg)}}
#loading-indicator{display:none;align-items:center;justify-content:center;padding:2.5rem 1rem;color:var(--ink-light);font-style:italic}
.msg-error{background:#fdf0f0;border:1px solid #e0b0b0;border-left:4px solid var(--red);padding:.9rem 1.1rem;border-radius:var(--radius);color:var(--red);font-size:.9rem;margin-top:1rem}

#list-section .panel{border-top-color:var(--gold)}
#list-items{list-style:none;margin:.5rem 0;max-height:420px;overflow-y:auto}
#list-empty-msg{display:block;text-align:center;color:var(--ink-faint);font-style:italic;font-size:.9rem;padding:1.5rem .5rem;white-space:pre-line}
.list-item{display:grid;grid-template-columns:1fr auto;gap:.3rem .6rem;padding:.65rem 0;border-bottom:1px dashed var(--border);align-items:start;font-size:.88rem}
.list-item:last-child{border-bottom:none}
.list-item-name{font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-item-shop{font-size:.8rem;color:var(--ink-faint);grid-column:1}
.list-item-price{font-family:var(--font-heading);font-weight:700;color:var(--green-dark);font-size:.95rem;grid-row:1;grid-column:2;text-align:right;white-space:nowrap}
.list-item-actions{grid-column:2;grid-row:2;text-align:right}
#list-total-row{display:flex;justify-content:space-between;align-items:center;padding:.7rem 0 .4rem;border-top:2px solid var(--border-dark);margin-top:.4rem;font-weight:700;font-family:var(--font-heading);font-size:1rem}
#list-total-amount{color:var(--green-dark)}
#export-buttons{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;border-top:1px solid var(--border);padding-top:1rem}
#export-buttons .btn{justify-content:center}
#list-controls{display:flex;justify-content:flex-end;margin-bottom:.4rem}

#donation-bar{background:#fff;border-top:3px solid #5a78ff;display:flex;align-items:center;justify-content:center;gap:1.2rem;padding:.9rem 1.5rem;flex-wrap:wrap;text-align:center}
.donation-text{font-size:.9rem;color:var(--ink-light);font-style:italic}
.mobilepay-btn{display:inline-flex;align-items:center;gap:.5rem;background:#5a78ff;color:#fff;font-family:var(--font-body);font-size:.9rem;font-weight:600;padding:.5rem 1.1rem;border-radius:6px;border:none;cursor:pointer;transition:background var(--transition)}
.mobilepay-btn:hover{background:#3a58df}
.mobilepay-logo{width:24px;height:24px;flex-shrink:0}

#donation-lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1000;align-items:center;justify-content:center;backdrop-filter:blur(3px)}
#donation-modal{background:#fff;border-radius:16px;padding:2rem 2.5rem 1.8rem;text-align:center;position:relative;box-shadow:0 8px 40px rgba(0,0,0,.35);max-width:340px;width:90%}
#donation-close{position:absolute;top:.7rem;right:.9rem;background:none;border:none;font-size:1.6rem;color:var(--ink-faint);cursor:pointer;line-height:1;padding:0}
#donation-close:hover{color:var(--ink)}
#donation-logo{display:flex;align-items:center;justify-content:center;gap:.5rem;font-family:Georgia,'Palatino Linotype',serif;font-size:1.7rem;margin-bottom:.6rem;letter-spacing:.5px}
#donation-icon{width:44px;height:44px;flex-shrink:0}
.donation-logo-find{font-weight:400;color:var(--ink)}
.donation-logo-billig{font-weight:700;color:var(--gold)}
#donation-subtitle{font-size:.9rem;color:var(--ink-faint);font-style:italic;margin-bottom:1.2rem}
#donation-qr{width:220px;height:220px;display:block;margin:0 auto;border-radius:8px}
#donation-thanks{margin-top:1.1rem;font-size:.88rem;color:var(--ink-light);font-style:italic}
#site-footer{background:var(--green-dark);color:rgba(245,240,230,.7);text-align:center;padding:1.4rem 1rem;font-size:.82rem;border-top:3px double var(--gold-light);font-style:italic}
#site-footer p+p{margin-top:.35rem}
#site-footer a{color:rgba(245,240,230,.7);text-decoration:underline}
#site-footer a:hover{color:#fff}

/* Info-knap */
#info-btn{position:fixed;bottom:1rem;right:1rem;width:24px;height:24px;border-radius:50%;background:transparent;border:1px solid var(--ink-faint);color:var(--ink-faint);font-family:var(--font-body);font-size:.7rem;font-weight:700;cursor:pointer;opacity:.3;transition:opacity var(--transition);line-height:1;padding:0;z-index:900}
#info-btn:hover{opacity:.8}

/* Info popup */
#info-lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1000;align-items:center;justify-content:center;backdrop-filter:blur(3px)}
#info-modal{background:var(--bg-card);border-radius:var(--radius);padding:2rem 2.2rem 1.8rem;position:relative;box-shadow:0 8px 40px var(--shadow);max-width:420px;width:90%;border-top:3px solid var(--green)}
#info-close{position:absolute;top:.7rem;right:.9rem;background:none;border:none;font-size:1.6rem;color:var(--ink-faint);cursor:pointer;line-height:1;padding:0}
#info-close:hover{color:var(--ink)}
#info-title{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--ink);margin-bottom:.6rem}
#info-intro{font-size:.88rem;color:var(--ink-light);margin-bottom:1rem}
#info-sources{list-style:none;display:flex;flex-direction:column;gap:.9rem;margin-bottom:1.1rem}
#info-sources li{font-size:.85rem;color:var(--ink);padding:.7rem .9rem;background:var(--bg);border-radius:var(--radius);border-left:3px solid var(--green)}
#info-sources li strong{display:inline;color:var(--green-dark)}
#info-sources a{color:var(--green);font-size:.8rem}
.distance-offer{display:inline-block;font-size:.72rem;font-weight:600;color:#b45309;background:#fef3c7;border-radius:99px;padding:.1rem .5rem;letter-spacing:.01em}
.distance-store{display:inline-block;font-size:.72rem;font-weight:600;color:#1d4ed8;background:#dbeafe;border-radius:99px;padding:.1rem .5rem;letter-spacing:.01em}
.info-tag{display:inline-block;margin-left:.5rem;font-size:.7rem;font-weight:600;color:var(--ink-faint);background:var(--bg-card);border:1px solid var(--border);border-radius:99px;padding:.1rem .5rem;vertical-align:middle;letter-spacing:.01em}
.info-shops{display:block;margin:.25rem 0 .3rem;font-size:.82rem;color:var(--ink-light);font-style:italic}
#info-privacy{font-size:.78rem;color:var(--ink-faint);font-style:italic;border-top:1px solid var(--border);padding-top:.8rem}

/* ── Butiksforslag ── */
.store-suggest-box{background:var(--green-bg);border:1px solid var(--green);border-radius:var(--radius);padding:.8rem 1rem;margin-bottom:.8rem}
.store-suggest-msg{font-size:.88rem;color:var(--ink);margin-bottom:.6rem}
.store-suggest-msg strong{color:var(--green-dark)}
.store-suggest-actions{display:flex;gap:.5rem;flex-wrap:wrap}

/* ── Tema-vælger ── */
#theme-switcher{position:fixed;bottom:1rem;left:1rem;display:flex;align-items:center;gap:.35rem;background:var(--bg-card);border:1px solid var(--border);border-radius:99px;padding:.3rem .5rem .3rem .7rem;box-shadow:0 2px 8px var(--shadow);z-index:900;opacity:.45;transition:opacity var(--transition)}
#theme-switcher:hover{opacity:1}
#theme-switcher-label{font-size:.68rem;font-weight:700;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.07em;margin-right:.2rem}
.theme-btn{font-size:.72rem;font-weight:600;padding:.22rem .65rem;border-radius:99px;border:1px solid var(--border);background:transparent;color:var(--ink-faint);cursor:pointer;transition:background var(--transition),color var(--transition);font-family:var(--font-body)}
.theme-btn:hover{background:var(--bg-dark);color:var(--ink)}
.theme-btn-active{background:var(--green);color:#fff;border-color:var(--green)}
.theme-btn-active:hover{background:var(--green-light);color:#fff}

@media print{
    #site-header,#search-section,#results-section,#site-footer,#export-buttons,#list-controls,.btn-danger{display:none!important}
    body{background:#fff;color:#000}
    #main-content{display:block}
    #list-section{position:static;max-width:600px;margin:2rem auto;padding:0}
    #list-section .panel{border:1px solid #999;box-shadow:none}
    .list-item{border-bottom:1px solid #ccc}
}

@media(max-width:900px){
    #main-content{grid-template-columns:1fr}
    #search-section,#results-section,#list-section{grid-column:1;grid-row:auto}
    #list-section{position:static}
}
@media(max-width:600px){
    #site-header{padding:1.4rem 1rem 1.2rem}
    #search-section{padding:1.2rem 1rem}
    #search-form{flex-direction:column;align-items:stretch}
    .form-group.radius-group{flex:unset;width:100%}
    #results-table{font-size:.82rem}
    #results-table td,#results-table th{padding:.5rem .6rem}
    .td-brand,.td-type,.td-distance,
    th[data-col="brand"],th[data-col="type"],th[data-col="distance"]{display:none}
}
