/*
Theme Name: QReator オリジナルテーマ
Theme URI: https://qreator.biz/
Author: QReator
Description: QReatorの営業用LP向けオリジナルテーマです。for WordPress 6.9+ / PHP 8.3.
Version: 2.1.1
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 8.1
Text Domain: qreator-original
*/

:root{
  --bg:#f7fbff;
  --bg-soft:#eef7ff;
  --panel:#ffffff;
  --panel-2:#f8fbff;
  --text:#142033;
  --heading:#0c1730;
  --muted:#5f708a;
  --line:rgba(14,35,77,.10);
  --brand:#18d2dc;
  --brand-2:#ffbf47;
  --brand-3:#5c7cff;
  --white:#ffffff;
  --shadow:0 20px 50px rgba(42,77,140,.12);
  --radius:28px;
  --content:1200px;
  --hero-image:none;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--text);background:linear-gradient(180deg,#f9fcff 0%,#f7fbff 40%,#f4f8fc 100%);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic UI","Yu Gothic",Meiryo,sans-serif;line-height:1.7}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button,input,textarea,select{font:inherit}
.wrap{max-width:var(--content);margin:0 auto;padding:0 24px}
.site-header{position:sticky;top:0;z-index:1000;backdrop-filter:blur(14px);background:rgba(255,255,255,.88);border-bottom:1px solid rgba(20,32,51,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:84px}
.branding{display:flex;align-items:center;gap:14px;min-width:0}.branding img{width:54px;height:54px;border-radius:16px;object-fit:cover;background:#fff;box-shadow:0 8px 20px rgba(13,31,74,.10)}
.branding-text{display:flex;flex-direction:column;min-width:0}.branding-text strong{font-size:1.08rem;line-height:1.1;color:var(--heading)}.branding-text span{font-size:.88rem;color:var(--muted)}
.menu-toggle{display:none;background:#fff;border:1px solid var(--line);color:var(--heading);padding:10px 14px;border-radius:999px;box-shadow:0 8px 20px rgba(20,32,51,.06)}
.primary-nav ul{display:flex;gap:10px;list-style:none;margin:0;padding:0;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.primary-nav a{display:inline-flex;padding:11px 16px;border-radius:999px;color:#33435d;font-weight:600}
.primary-nav a:hover,.primary-nav .current-menu-item>a{background:rgba(92,124,255,.08);color:var(--heading)}
.nav-cta a{background:linear-gradient(135deg,var(--brand),#42b8ff);color:#062436;font-weight:800;box-shadow:0 14px 30px rgba(24,210,220,.24)}
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#ffffff 0%,#f5fbff 100%)}
.hero:before{content:"";position:absolute;inset:18px 18px auto;bottom:18px;border-radius:40px;background:linear-gradient(135deg,rgba(92,124,255,.08),rgba(24,210,220,.08));z-index:0}
.hero-media{position:absolute;inset:0;background-image:var(--hero-image);background-position:center;background-size:cover;opacity:.18;filter:saturate(1.06)}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at top right, rgba(24,210,220,.18), transparent 26%),radial-gradient(circle at 8% 18%, rgba(255,191,71,.18), transparent 22%),linear-gradient(180deg,rgba(255,255,255,.68),rgba(247,251,255,.98) 86%)}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.12fr) minmax(340px,.88fr);gap:42px;align-items:center;min-height:88vh;padding:76px 0 88px}
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:999px;background:rgba(255,255,255,.86);border:1px solid rgba(92,124,255,.12);font-size:.92rem;color:#314567;box-shadow:0 10px 24px rgba(42,77,140,.08)}
.hero h1{font-size:clamp(2.9rem,5vw,5.4rem);line-height:1.02;margin:20px 0 18px;letter-spacing:.01em;color:var(--heading)}.hero h1 .accent{color:#ffb52f}
.hero-text{font-size:1.08rem;color:#415066;max-width:760px;margin:0 0 28px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:20px}
.button{display:inline-flex;align-items:center;justify-content:center;padding:15px 26px;border-radius:999px;font-weight:800;border:1px solid transparent;transition:.2s ease;background:linear-gradient(135deg,var(--brand),#47b8ff);color:#062436;box-shadow:0 14px 28px rgba(24,210,220,.18)}.button:hover{transform:translateY(-1px)}
.button.is-secondary{background:#fff;color:var(--heading);border-color:rgba(20,32,51,.12);box-shadow:0 12px 24px rgba(13,31,74,.07)}
.hero-badges{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}.hero-badge{display:inline-flex;padding:8px 12px;border-radius:999px;border:1px solid rgba(92,124,255,.14);background:#fff;font-size:.88rem;color:#4a5d7c;box-shadow:0 8px 18px rgba(13,31,74,.05)}
.hero-card{background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(240,248,255,.95));border:1px solid rgba(92,124,255,.12);border-radius:32px;padding:32px;box-shadow:var(--shadow)}
.hero-card h2{margin:16px 0 10px;font-size:1.95rem;line-height:1.22;color:var(--heading)}.hero-card p{margin:0;color:var(--muted)}
.hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:20px}.stat-item{background:#fff;border:1px solid rgba(92,124,255,.10);padding:18px;border-radius:20px;box-shadow:0 12px 28px rgba(20,32,51,.06)}.stat-item strong{display:block;font-size:1.7rem;line-height:1.15;margin-bottom:6px;color:var(--brand-3)}
.section{padding:96px 0}.section-soft{background:linear-gradient(180deg,#ffffff 0%,#f5faff 100%)}
.section-head{display:flex;justify-content:space-between;gap:24px;align-items:end;margin-bottom:34px}.section-head.centered{display:block;text-align:center;max-width:860px;margin:0 auto 34px}
.section-head h2{margin:0;font-size:clamp(2rem,4vw,3.1rem);line-height:1.15;color:var(--heading)}.section-head p{margin:0;max-width:720px;color:var(--muted)}
.issues-grid,.reason-grid,.support-grid,.process-grid{display:grid;gap:22px}.issues-grid,.reason-grid,.process-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.support-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.issue-card,.reason-card,.support-card,.process-card,.faq-item,.contact-form-shell,.work-card,.service-card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.issue-card,.reason-card,.support-card,.process-card{padding:28px}
.issue-mark,.reason-no,.process-no{display:inline-flex;align-items:center;justify-content:center;min-width:54px;height:54px;border-radius:18px;background:linear-gradient(135deg,rgba(24,210,220,.14),rgba(92,124,255,.16));border:1px solid rgba(92,124,255,.12);color:var(--brand-3);font-weight:800;margin-bottom:14px}
.issue-card h3,.reason-card h3,.support-card h3,.process-card h3{margin:0 0 10px;font-size:1.3rem;line-height:1.3;color:var(--heading)}.issue-card p,.reason-card p,.support-card p,.process-card p,.work-body p,.service-body p{margin:0;color:var(--muted)}
.services-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:26px}.service-card{overflow:hidden}
.service-media{aspect-ratio:16/10;background:#eaf4ff;overflow:hidden}.service-media img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}.service-card:hover .service-media img,.work-card:hover .service-media img{transform:scale(1.03)}
.service-body{padding:28px}.service-meta{display:flex;align-items:center;gap:12px;margin-bottom:14px;justify-content:space-between;flex-wrap:wrap}.service-logo{width:60px;height:60px;border-radius:18px;object-fit:cover;background:#fff;padding:6px;box-shadow:0 10px 22px rgba(20,32,51,.08)}
.service-tag,.work-subtext{display:inline-flex;padding:6px 12px;border-radius:999px;background:rgba(92,124,255,.08);color:#3552b6;font-size:.82rem;font-weight:700}
.service-body h3,.work-body h3{font-size:1.55rem;line-height:1.25;margin:0 0 12px;color:var(--heading)}.service-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.bullet-list{margin:16px 0 0;padding-left:1.1rem;color:#415066}.bullet-list li+li{margin-top:6px}
.works-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}.work-card{overflow:hidden}.work-body{padding:24px}.work-subtext{margin-bottom:12px}
.faq-list{display:grid;gap:16px}.faq-item{padding:0 24px;background:#fff}.faq-item summary{cursor:pointer;list-style:none;padding:24px 0;font-weight:800;font-size:1.05rem;color:var(--heading)}.faq-item summary::-webkit-details-marker{display:none}.faq-answer{padding:0 0 24px;color:var(--muted)}
.contact-box{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.88fr);gap:24px;background:linear-gradient(135deg,#eefbff,#f5f7ff);border:1px solid rgba(24,210,220,.16);border-radius:34px;padding:34px;box-shadow:var(--shadow)}
.contact-copy h2{margin:0 0 12px;font-size:clamp(2rem,4vw,3.2rem);line-height:1.15;color:var(--heading)}.contact-copy p{margin:0 0 22px;color:#415066}.contact-points{display:grid;gap:12px;margin:0 0 24px}.contact-point{padding:14px 16px;border-radius:18px;background:#fff;border:1px solid rgba(92,124,255,.10);box-shadow:0 10px 24px rgba(13,31,74,.05)}
.contact-form-shell{padding:24px;background:rgba(255,255,255,.86)}.form-placeholder h3{margin:16px 0 10px;color:var(--heading)}.form-placeholder p{margin:0;color:var(--muted)}
.site-footer{padding:30px 0 48px;border-top:1px solid rgba(20,32,51,.08);background:#ffffff}.footer-inner{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;align-items:flex-start}.footer-copy{color:#52647f;font-size:.95rem}.footer-note{margin-top:10px;color:var(--muted);max-width:680px;font-size:.92rem}.footer-links{display:flex;gap:14px;flex-wrap:wrap}.footer-links a{color:#52647f}
.content-page{padding:64px 0}.entry-card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);padding:32px;border-radius:28px;box-shadow:var(--shadow)}.entry-card h1,.entry-card h2,.entry-card h3{line-height:1.3;color:var(--heading)}.entry-card p,.entry-card li{color:#415066}.screen-reader-text{position:absolute;left:-9999px}
@media (max-width: 1100px){.hero-inner,.contact-box,.services-grid,.works-grid,.support-grid,.issues-grid,.reason-grid,.process-grid{grid-template-columns:1fr}}
@media (max-width: 860px){.menu-toggle{display:inline-flex}.primary-nav{position:absolute;left:0;right:0;top:100%;background:rgba(255,255,255,.97);border-bottom:1px solid rgba(20,32,51,.08);display:none}.primary-nav.is-open{display:block}.primary-nav ul{padding:16px 24px 24px;flex-direction:column;align-items:stretch}.primary-nav a{border-radius:16px}.section-head{display:block}.section-head p{margin-top:12px}.hero:before{inset:10px 10px auto;bottom:10px}}
@media (max-width: 640px){.wrap{padding:0 18px}.hero-inner{min-height:auto;padding:62px 0 72px}.header-inner{min-height:72px}.branding-text span{display:none}.hero-actions,.hero-badges,.service-links,.footer-inner{flex-direction:column;align-items:flex-start}.hero-card,.contact-box{padding:22px}.stat-item strong{font-size:1.45rem}.faq-item{padding:0 18px}}


/* Contact form optimization */
.contact-form-shell{padding:28px;background:#fff;border:1px solid rgba(92,124,255,.12);box-shadow:0 18px 42px rgba(13,31,74,.08)}
.contact-form-shell .eyebrow{display:inline-flex;margin-bottom:16px}
.form-placeholder{display:flex;flex-direction:column;justify-content:center;min-height:100%;padding:8px 4px}
.form-placeholder h3{margin:12px 0 10px;color:var(--heading);font-size:1.4rem;line-height:1.4}
.form-placeholder p{margin:0;color:#5b6b86;line-height:1.8}
.contact-form-shell form{display:grid;gap:14px}
.contact-form-shell p{margin:0}
.contact-form-shell label{display:block;font-size:.92rem;font-weight:700;color:var(--heading);margin:0 0 8px}
.contact-form-shell input:not([type="submit"]),
.contact-form-shell input:not([type="checkbox"]):not([type="radio"]),
.contact-form-shell select,
.contact-form-shell textarea{width:100%;padding:14px 16px;border:1px solid rgba(92,124,255,.18);border-radius:14px;background:#f9fbff;color:var(--heading);font:inherit;line-height:1.6;transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease}
.contact-form-shell textarea{min-height:160px;resize:vertical}
.contact-form-shell input:focus,
.contact-form-shell select:focus,
.contact-form-shell textarea:focus{outline:none;border-color:rgba(24,210,220,.9);box-shadow:0 0 0 4px rgba(24,210,220,.12);background:#fff}
.contact-form-shell input::placeholder,
.contact-form-shell textarea::placeholder{color:#8a96ad}
.contact-form-shell .wpcf7-spinner{margin:8px 0 0}
.contact-form-shell .wpcf7-not-valid-tip{font-size:.85rem;margin-top:6px}
.contact-form-shell .wpcf7 form .wpcf7-response-output{margin:18px 0 0;padding:12px 14px;border-radius:14px}
.contact-form-shell input[type="submit"],
.contact-form-shell button[type="submit"]{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:54px;border:none;border-radius:999px;padding:0 22px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:800;font-size:1rem;cursor:pointer;box-shadow:0 16px 28px rgba(24,210,220,.22);transition:transform .2s ease, box-shadow .2s ease, opacity .2s ease}
.contact-form-shell input[type="submit"]:hover,
.contact-form-shell button[type="submit"]:hover{transform:translateY(-1px);box-shadow:0 20px 34px rgba(24,210,220,.28)}
.contact-form-shell .wpcf7-list-item{margin:0 16px 0 0}
.contact-form-shell .wpcf7-acceptance label,
.contact-form-shell .wpcf7-checkbox label,
.contact-form-shell .wpcf7-radio label{display:flex;align-items:flex-start;gap:10px;font-weight:500;color:#53627a}


/* Hero visual enhancement */
.hero{padding-top:18px}
.hero-inner{grid-template-columns:minmax(0,1fr) minmax(380px,.96fr);gap:52px;min-height:auto;padding:84px 0 96px}
.hero-copy{position:relative;z-index:2}
.hero-text{max-width:640px;font-size:1.02rem}
.hero-visual{position:relative;min-height:640px}
.hero-visual-main,
.hero-visual-stack,
.hero-visual-note{position:absolute;background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);overflow:hidden}
.hero-visual-main{top:0;right:0;width:86%;max-width:560px}
.hero-visual-main img{display:block;width:100%;aspect-ratio:16/10;object-fit:cover}
.hero-visual-stack{width:42%;max-width:240px}
.hero-visual-stack img{display:block;width:100%;aspect-ratio:4/5;object-fit:cover}
.hero-visual-stack-top{top:72px;left:0;transform:rotate(-6deg)}
.hero-visual-stack-bottom{bottom:54px;left:24px;transform:rotate(4deg)}
.hero-visual-note{right:18px;bottom:0;width:82%;padding:28px;background:rgba(255,255,255,.95);backdrop-filter:blur(10px)}
.hero-visual-note h2{margin:14px 0 10px;font-size:1.9rem;line-height:1.2;color:var(--heading)}
.hero-visual-note p{margin:0;color:var(--muted)}
.hero-visual:before,
.hero-visual:after{content:"";position:absolute;border-radius:999px;filter:blur(6px);z-index:0}
.hero-visual:before{width:150px;height:150px;right:18px;top:26px;background:radial-gradient(circle, rgba(24,210,220,.24), transparent 68%)}
.hero-visual:after{width:200px;height:200px;left:10px;bottom:90px;background:radial-gradient(circle, rgba(255,191,71,.20), transparent 70%)}
.hero-card{display:none}

/* Contact form polish */
.contact-form-shell{padding:28px;border-radius:28px}
.contact-form-shell form{display:grid;gap:14px}
.contact-form-shell p{margin:0}
.contact-form-shell label{display:grid;gap:8px;color:var(--heading);font-weight:700}
.contact-form-shell input[type="text"],
.contact-form-shell input[type="email"],
.contact-form-shell input[type="tel"],
.contact-form-shell input[type="url"],
.contact-form-shell textarea,
.contact-form-shell select{width:100%;padding:14px 16px;border:1px solid rgba(20,32,51,.12);border-radius:16px;background:#fff;transition:border-color .2s ease, box-shadow .2s ease}
.contact-form-shell textarea{min-height:140px;resize:vertical}
.contact-form-shell input:focus,
.contact-form-shell textarea:focus,
.contact-form-shell select:focus{outline:none;border-color:rgba(24,210,220,.72);box-shadow:0 0 0 4px rgba(24,210,220,.14)}
.contact-form-shell input[type="submit"],
.contact-form-shell button[type="submit"],
.contact-form-shell .wpcf7-submit{display:inline-flex;justify-content:center;align-items:center;border:0;border-radius:999px;padding:15px 24px;font-weight:800;background:linear-gradient(135deg,var(--brand),#47b8ff);color:#062436;box-shadow:0 14px 28px rgba(24,210,220,.18);cursor:pointer}
.contact-form-shell .wpcf7-spinner{margin:8px 0 0}
.form-placeholder{display:grid;place-items:center;min-height:240px;text-align:center;color:var(--muted)}
.form-placeholder p{margin:0}

@media (max-width: 980px){
  .hero-inner{grid-template-columns:1fr;gap:28px;padding:64px 0 72px}
  .hero-visual{min-height:560px}
  .hero-visual-main{position:relative;width:100%;max-width:none}
  .hero-visual-stack-top{top:18px;left:16px}
  .hero-visual-stack-bottom{bottom:120px;left:16px}
  .hero-visual-note{right:0;bottom:0;width:100%}
}

@media (max-width: 640px){
  .hero h1{font-size:clamp(2.5rem,10vw,4rem)}
  .hero-visual{min-height:440px}
  .hero-visual-stack{display:none}
  .hero-visual-main img{aspect-ratio:16/11}
  .hero-visual-note{padding:22px}
}
